您的位置:首页 > 数据库

类型化(Type)的DataSet (使用强类型的DataSet。定义的数据库表一定要有主键,否则不能使用)

2013-09-03 23:57 471 查看
使用强类型的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();

}
}
}




内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐