C# DataTable 詳解

来源:http://www.cnblogs.com/ldyblogs/archive/2017/09/06/datatable.html
-Advertisement-
Play Games

添加引用 創建表 創建列 創建行 賦值和取值 篩選行 刪除行 複製表 表排序 ...


添加引用

using System.Data;

創建表

//創建一個空表
DataTable dt = new DataTable();
//創建一個名為"Table_New"的空表
DataTable dt = new DataTable("Table_New");

創建列

//1.創建空列
DataColumn dc = new DataColumn();
dt.Columns.Add(dc);
//2.創建帶列名和類型名的列(兩種方式任選其一)
dt.Columns.Add("column0", System.Type.GetType("System.String"));
dt.Columns.Add("column0", typeof(String));
//3.通過列架構添加列
DataColumn dc = new DataColumn("column1",System.Type.GetType("System.DateTime"));
DataColumn dc = new DataColumn("column1", typeof(DateTime));
dt.Columns.Add(dc);

創建行

//1.創建空行
DataRow dr = dt.NewRow();
dt.Rows.Add(dr);
//2.創建空行
dt.Rows.Add();
//3.通過行框架創建並賦值
dt.Rows.Add("張三",DateTime.Now);//Add裡面參數的數據順序要和dt中的列的順序對應 
//4.通過複製dt2表的某一行來創建
dt.Rows.Add(dt2.Rows[i].ItemArray);

賦值和取值

//新建行的賦值
DataRow dr = dt.NewRow();
dr[0] = "張三";//通過索引賦值
dr["column1"] = DateTime.Now; //通過名稱賦值
//對錶已有行進行賦值
dt.Rows[0][0] = "張三"; //通過索引賦值
dt.Rows[0]["column1"] = DateTime.Now;//通過名稱賦值
//取值
string name=dt.Rows[0][0].ToString();
string time=dt.Rows[0]["column1"].ToString();

篩選行

//選擇column1列值為空的行的集合
DataRow[] drs = dt.Select("column1 is null");
//選擇column0列值為"李四"的行的集合
DataRow[] drs = dt.Select("column0 = '李四'");
//篩選column0列值中有"張"的行的集合(模糊查詢)
DataRow[] drs = dt.Select("column0 like '張%'");//如果的多條件篩選,可以加 and 或 or
//篩選column0列值中有"張"的行的集合併按column1降序排序
DataRow[] drs = dt.Select("column0 like '張%'", "column1 DESC");

刪除行

//使用DataTable.Rows.Remove(DataRow)方法
dt.Rows.Remove(dt.Rows[0]);
//使用DataTable.Rows.RemoveAt(index)方法
dt.Rows.RemoveAt(0);
//使用DataRow.Delete()方法
dt.Row[0].Delete();
dt.AcceptChanges();

//-----區別和註意點-----
//Remove()和RemoveAt()方法是直接刪除
//Delete()方法只是將該行標記為deleted,但是還存在,還可DataTable.RejectChanges()回滾,使該行取消刪除。
//用Rows.Count來獲取行數時,還是刪除之前的行數,需要使用DataTable.AcceptChanges()方法來提交修改。
//如果要刪除DataTable中的多行,應該採用倒序迴圈DataTable.Rows,而且不能用foreach進行迴圈刪除,因為正序刪除時索引會發生變化,程式發生異常,很難預料後果。
for (int i = dt.Rows.Count - 1; i >= 0; i--)
{
  dt.Rows.RemoveAt(i);
}

複製表

//複製表,同時複製了表結構和表中的數據
DataTable dtNew = new DataTable();
dtNew = dt.Copy();
//複製表
DataTable dtNew = dt.Copy();  //複製dt表數據結構
dtNew.Clear()  //清空數據
for (int i = 0; i < dt.Rows.Count; i++)
{
    if (條件語句)
    {
         dtNew.Rows.Add(dt.Rows[i].ItemArray);  //添加數據行
    }
}
//克隆表,只是複製了表結構,不包括數據
DataTable dtNew = new DataTable();
dtNew = dt.Clone();
//如果只需要某個表中的某一行
DataTable dtNew = new DataTable();
dtNew = dt.Copy();
dtNew.Rows.Clear();//清空表數據
dtNew.ImportRow(dt.Rows[0]);//這是加入的是第一行

表排序

DataTable dt = new DataTable();//創建表
dt.Columns.Add("ID", typeof(Int32));//添加列
dt.Columns.Add("Name", typeof(String));
dt.Columns.Add("Age", typeof(Int32));
dt.Rows.Add(new object[] { 1, "張三" ,20});//添加行
dt.Rows.Add(new object[] { 2, "李四" ,25});
dt.Rows.Add(new object[] { 3, "王五" ,30});
DataView dv = dt.DefaultView;//獲取表視圖
dv.Sort = "ID DESC";//按照ID倒序排序
dv.ToTable();//轉為表


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.1 關於運維人員 1.1.1 運維的職責 1.保證伺服器7*24小時 運行 2.保證數據不能丟 3.提高用戶的體驗(網站打開的速度) 1.1.2 運維原則 簡單、易用、高效 簡單、粗暴 第2章 電腦的組成 2.1 電腦組成 包含: 1.顯示器、 2.機箱(主機)| | CPU | 硬碟 | ...
  • 我一直無法解決Ubuntu QQ問題,而最近我重裝ubuntu之後在網路上找到與QQ相關的內容,網上有大神開發出了新版的wineQQ,解決了我們對QQ的需求。經過嘗試,完成了QQ安裝 如圖 安裝的是wine QQ 那麼 1.首先安裝wine 第一條命令 添加源 第二條 第三條 2.下載wineQQ  ...
  • 本文不進行大量的原理敘述,主要講解實操 實驗環境: 虛擬機:vm Ubuntu:16.04(需要安裝桌面),作為服務端 服務端IP:192.168.193.128 實踐: 1.安裝dhcp服務 apt-get install isc-dhcp-server -y #如果提示E: 無法定位軟體包 is ...
  • 簡單來說內網穿透的目的是:讓外網能訪問你本地的應用,例如在外網打開你本地http://127.0.0.1指向的Web站點。 最近公司的花生殼到期了,要續費,發現價格一直在漲,都是5年以上的老用戶,旗艦版都沒有實現內網完全穿透,打算自己動手替換這個服務,中間走了不少的彎路,這裡記錄一些文字為大家提供參 ...
  • system定義 首先要知道,system函數是c庫中的函數,而不是系統調用。其實system函數使用起來並不複雜,難就難在對其返回值的理解。這個問題,下文會詳細分析。參數的話,很簡單,就是終端的命令即可。這是因為system函數的實現中調用了shell的緣故。 system優缺點 優點: 可以讓c ...
  • 環境:ubuntu16.04 交叉編譯器版本:4.8.3 依賴x264,lame x264: 1.wget ftp://ftp.videolan.org/pub/x264/snapshots/last_stable_x264.tar.bz2 2.tar xvf last_stable_x264.ta ...
  • (green) short pairwise alignment / detailed edit model; (yellow) database search / divergent homology detection; (red) whole genome alignment / alignm ...
  • 參數檢查 跨目錄執行腳本但維持腳本與"."的相對位置不變 彩色日誌輸出 使用臨時文件, 防止使用的文件與已知文件重名而被替換 輸出到標準輸出的同時寫入到文件 逐行處理文本文件,註意文本要set fileformat=unix確保格式正確 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...