在行之间添加Datarow?

时间:2009-06-24 14:31:20

标签: c# datatable datarow

如何在数据表中的现有行之间添加行? 感谢

2 个答案:

答案 0 :(得分:13)

dataTable.Rows.InsertAt(DataRow row, int position);


样品:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;

namespace ConsoleApplication1
{
    class Program
    {
        static DataTable getDataTable()
        {
            DataTable table = new DataTable();
            table.Columns.Add("userID", typeof(int));
            table.Columns.Add("userName", typeof(string));
            table.Columns.Add("isAwesome", typeof(bool));
            return table;
        }

        static DataRow getRow(DataTable table, int userID, string userName, bool isAwesome)
        {
            DataRow row = table.NewRow();
            row["userID"] = userID;
            row["userName"] = userName;
            row["isAwesome"] = isAwesome;
            return row;
        }

        static void printTable(DataTable table)
        {
            foreach (DataRow row in table.Rows)
            {
                foreach (object val in row.ItemArray)
                {
                    Console.Write("{0}, ", val);
                }
                Console.WriteLine();
            }
        }


        static void Main(string[] args)
        {
            DataTable table = getDataTable();
            table.Rows.Add(getRow(table, 1, "Juliet", true));
            table.Rows.Add(getRow(table, 2, "Sean Hannity", false));
            table.Rows.Add(getRow(table, 3, "Charles Darwin", true));

            Console.WriteLine("Before:");
            printTable(table);

            // adding a row at index 1, between me and Sean Hannity
            Console.WriteLine("------------\nAfter:");
            DataRow barackRow = getRow(table, 4, "Barack Obama", true);
            table.Rows.InsertAt(barackRow, 1);
            printTable(table);

            Console.Write("Press any key. . .");
            Console.ReadKey(true);
        }        
    }
}

答案 1 :(得分:2)

样品:

            DataTable table = new DataTable();
            table.Columns.Add("a", typeof(int));

            DataRow r = table.NewRow();
            r[0] = 10;
            table.Rows.Add(r);

            r = table.NewRow();
            r[0] = 12;
            table.Rows.InsertAt(r, 0);