时间:2021-07-01 10:21:17 帮助过:3人阅读
- // 2015/07/08
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Data;
- using System.Data.SqlClient;
- namespace DataTapleSample
- {
- class Program
- {
- static void Main(string[] args)
- {
- // 通用的专门用来保存数据库中数据的类型
- DataTable table = new DataTable();
- // 在DataTable 中保存数据之前,必须先定义结构
- DataColumn stuid =
- //new DataColumn("StuId",System.Type.GetType("System.Int32"));
- new DataColumn("StuId",typeof(int));//简写方式和前者等价
- DataColumn stuname = new DataColumn("stuName",typeof(string));
- DataColumn stuaddress = new DataColumn("stuaddress",typeof(string));
- // 创建表的结构
- table.Columns.Add(stuid);
- table.Columns.Add(stuname);
- table.Columns.Add(stuaddress);
- // 表的约束
- // 主键约束
- table.PrimaryKey = new DataColumn[]{stuid};
- // 非空约束
- // stuaddress.AllowDBNull = false;
- // 唯一约束:stuname.Unique;
- // 如何在 DataTable 中保存数据
- // DataRow 表示保存在 DataTable 中的一行数据
- DataRow row = table.NewRow();
- // 使用 NewRow 方法创建的行,结构与表是相同的(如下三种方法,建议第一种)
- // row[stuid] = 1;
- // row[1] = "XXXX";
- // row[stuaddress] = "XXXX";
- row[stuid] = 7;
- row[stuname] = "XX";
- row[stuaddress] = "XXX";
- // 现在加入到 DataTable 中
- table.Rows.Add(row);
- // 访问保存在 DataTable 中的数据
- foreach (DataRow r in table.Rows)
- {
- Console.WriteLine("stuid:{0},stuName:{1},stuaddress:{2}",r[0],r[1],r[2]);
- }
- Console.ReadKey();
- }
- }
- }
- //////////////////////////////////////////////////////////////
- // next
- // 2015/07/08
- // DataTable && SqlDataReader
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Data;
- using System.Data.SqlClient;
- namespace StuDataTable
- {
- class Program
- {
- static void Main(string[] args)
- {
- // 保存在 DataTable 中
- DataTable table = new DataTable();
- string connectionString = "server=.;database=BookSample;uid=sa;pwd=123456";
- using (SqlConnection connection = new SqlConnection(connectionString))
- {
- string sql = "select ID,StuName,Phone from students";
- SqlCommand cmd = new SqlCommand(sql,connection);
- connection.Open();
- using (SqlDataReader reader = cmd.ExecuteReader())
- {
- // 根据查询结果的结构来创建对应的 DataTable
- int columnCount = reader.FieldCount; // 查询结果的列数
- // 逐列创建
- for (int i = 0; i < columnCount; i++)
- {
- DataColumn column = new DataColumn(
- reader.GetName(i),
- reader.GetFieldType(i)
- );
- table.Columns.Add(column);
- }
- // 逐行从数据库中读取数据
- while (reader.Read())
- {
- DataRow row = table.NewRow();
- for (int i = 0; i < columnCount; i++)
- {
- row[i] = reader[i];
- }
- table.Rows.Add(row);
- }
- }
- }
- // 现在数据库中的数据已经保存到内存中特殊的集合中
- foreach (DataRow row in table.Rows)
- {
- // 将 ID 读取出来
- Console.WriteLine(row["ID"]);
- }
- Console.ReadKey();
- }
- }
- }
- /*
- 相关阅读:
- https://msdn.microsoft.com/zh-cn/library/system.data.datatable.aspx
- https://msdn.microsoft.com/zh-cn/library/system.data.sqlclient.sqldatareader.aspx
- */
DataTable && SqlDataReader帮助理解小程序
标签: