使用强类型的DataSet的时候一定要设置主键,假如说你在拖一个表到数据集来创建强类型DataSet的时候 而那个表又没有设置主键
那么你只有在数据集里把你拖入的那个表删除,重新拖入。或者点击你拖入到数据集的那个表,把鼠标移动到 "表名+TableAdapter"栏
其实也就就是倒数第二栏。点击右键,属性->配置 然后点击完成就好了
假如说你将表拖入到数据集后,你又在数据库表里添加了某个字段。那么此时你在“配置”里点击“查询生成器”将你后来添加的那个字段勾选上
然后点“完成”就好了。
//创建强类型DataSet,首先在你的项目名称里添加"新建项"选择"数据集"数据集的默认名字为DataSet1。接着在visual studio的服务器资源管理器连接数据库,在数据连接的表里面拖一个你需要的表(例如xs)到DataSet1数据集中,【当你要拖一个表到你添加的"数据集"中的时候,它的意思就是“请为我拖近进来的这个表创建强类型DataSet”】【注意,这个拖是拖的表的结构,数据并没有拖过来】这时候就会自动给你生成一个类xsTableAdapter。类名是以你的表名开头的,这里我拖的是xs表,所以类名是以xs开头的 private void button6_Click(object sender, EventArgs e) { //TableAdapter 提供应用程序和数据库之间的通信。更具体地说,TableAdapter 连接到数据库,执行查询或存储过程,并返回用返回数据填充的新数据表或是用返回数据填充现有的DataTable。TableAdapter 还用于将更新数据从应用程序发送回数据库。 xsTableAdapter adapter = new xsTableAdapter(); DataSet1.xsDataTable dt = adapter.GetData();//GetData()是返回一个用数据填充了的新的DataTable。然后给这个DataTable赋给dt //GetData()与Fill()的区别 //如果我们已经有了一个DataTable了 我再想把数据填充到这个DataTable里就用fill方法(fill方法一般是数据绑定用的比较多)如果没有现有的DataTable 我直接就想得到这个数据,那么就用GetData (GetData 内部会为你创建一个DataTable,然后用数据填充这个DataTable ,然后再把这个已经填充了数据的DataTable 返回给你 。如果你想你获得这个DataTable ,那么你在外部定义一个DataTable 类型的表来接收它就可以了) /* for (int i = 0; i < dt.Count; i++)//用for循环遍历dt表的总行数。dt.Count表示 dt表的总行数 { DataSet1.xsRow xsrow = dt[i]; //dt[i]是指dt表的第i行 MessageBox.Show(xsrow.姓名.ToString()); //输出所以行的姓名 } */ DataSet1.xsRow rw = dt[0]; //取dt表的第一行(索引从0开始)。强类型DataSet使用方法不要rows。直接dt[0] //而弱类型的DataSet取行是这样的:DataRow drow = dt.Rows[0]; //取得dt表中的第一行 //MessageBox.Show(rw.姓名); //输出第一行的姓名值 //***************************************强类型Datset的修改,并且更新。 //将dt表的第1行的总学分修改为“50”-------------updata rw.专业名 = null; adapter.Update(dt); MessageBox.Show("数据修改成功"); //通过强类型DataSet插入一条数据到xs表------------insert adapter.Insert("001242","里维斯","计算机",0,"2006-10-12",50,null); MessageBox.Show("数据插入成功"); //--------------------------------------------自定义Delete----(当然你也可以自定义select insert) //因为adapter自己生成的默认adapter.Delete()不好用,那么我们就自己来定义一个Delete() //在数据集里找到你拖入进来的那个表,把鼠标移动到表的最上方。右键->添加->查询(Query)->使用SQL语句->下一步,这里根据我们的需要我选择了Delete(D)->下一步。然后再那个框框里写你自己的delete语句->下一步->根据自己需要重命名一下方法名->完成。 调用方法如下 //adapter.DeleteQuery学号("001242"); //这时候我又根据上面的注释创建一个select查询,写完select语句后,在命名方法名的时候,将填充DataTable方法命名为"Fill专业名"返回DataTable方法命名为"GetData专业名"。 那么使用方法如下 DataSet1.xsDataTable dt2 = adapter.GetData计算机(); //注意这里调用的是我自己定义的GetData专业名方法名哦 DataSet1.xsRow rw2 = dt2[dt2.Count-1]; //取得dt2表的最后一行(索引从0开始) MessageBox.Show(rw2.姓名); //输出dt表最后一行的姓名列 //****************************************************强类型DataSet空值处理 //假如数据库里xs表的第一行的“专业名”字段值为NULL //MessageBox.Show(rw.专业名);//错误的取法,这样取值的话就会报异常“表“xs”中列“专业名”的值为 DBNull。” //所我们只能这么来取 if (rw.Is专业名Null()) { MessageBox.Show("专业名值为NULL"); } else { MessageBox.Show(rw.专业名); } }
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using 可空类型.DataSet1TableAdapters;
namespace 可空类型
{
class Program
{
static void Main(string[]args)
{
//强类型DataSet的使用。首先把Visual studio找到工具->连接数据库。右键项目名称添加新项->数据集,这里默认的数据集名称是DataSet1.xsd。此时将服务器资源管理器栏名下的数据连接里面你需要的某个表(这里是拖入的是T_user)拖入到DataSet1.xsd中 .这时就会自动生成一堆类其中就包含T_userTableAdapter。也就是表名+TableAdapter,表名+DataTable,表名+Row
T_userTableAdapter adapter =new T_userTableAdapter();
可空类型.DataSet1.T_userDataTable table = adapter.GetData();
for(int i = 0; i < table .Count; i++)//用for循环遍历table表的总行数。table.Count表示 table表的总行数
{
可空类型.DataSet1.T_userRow row = table[i]; //强类型DataSet使用方法不要rows。直接table[i]
//DataSet1.T_userRowdw = table.Rows[1]; dw["name"] = "周泉"; //弱类型DataSet使用方法
Console.WriteLine(row.name);
}
//下面尝试一下强类型Datset的修改,并且更新。将table表的第2行的name修改为“张三丰”
table[1].name = "邓媛";
//把更新的数据写入数据库表
adapter.Update(table);
Console.WriteLine("数据修改成功");
Console.ReadKey();
}
}
}