C# 数据库知识点及连接数据库方法

上传人:z**** 文档编号:148193529 上传时间:2022-09-04 格式:DOCX 页数:32 大小:144.74KB
返回 下载 相关 举报
C# 数据库知识点及连接数据库方法_第1页
第1页 / 共32页
C# 数据库知识点及连接数据库方法_第2页
第2页 / 共32页
C# 数据库知识点及连接数据库方法_第3页
第3页 / 共32页
点击查看更多>>
资源描述
1、概述2、连接字符串的写法3、SqlConnection 对象4、SqlCommand 对象5、SqlDataReader 对象6、DataSet 对象7、释放资源1、概述 提供了丰富的数据库操作,这些操作可以分为三个步骤:第一,使用 SqlConnection 对象连接数据库;第二,建立 SqlCommand 对象,负责 SQL 语句的执 行和存储过程的调用;第三,对 SQL 或存储过程执行后返回的“结果”进行操 作。对返回“结果”的操作可以分为两类:一是用 SqlDataReader 直接一行一行的读取数据集; 二是 DataSet 联合 SqlDataAdapter 来操作数据库。两者比较:SqlDataReader 时刻与远程数据库服务器保持连接, 将远程的数据通过“流”的形式单向传输给客户端,它 是“只读”的。由于是直接访问数据库,所以效率较高, 但使用起来不方便。DataSet 一次性从数据源获取数据到本地,并在本地建立一个微型数据库(包含表、行、列、规则、表之间的关系等),期间可以断开与服务器的连接,使用 SqlDataAdapter 对象操作“本地微型数据库”,结束后 通过 SqlDataAdapter 一次性更新到远程数据库服务 器。这种方式使用起来更方,便简单。但性能较第一 种稍微差一点。(在一般的情况下两者的性能可以忽略 不计。)一张十分出名的 ADO.NET 结构图:数据库Da capable Colle ct ion数据表b ta RgwCo I led i anDataColumnCollectionConstra tntCo H ect i onDataSetDa t 自 Re 他 tio n Coll e ct ionXML2、连接字符串的写法 string connectString = Data Source=.;InitialCatalog=Student;Integrated Security=True;3、SqlConnection 对象命名空间:System.Data.SqlClient.SqlConnection;返回数据库连接对象,参数字符串。实例化“连接对象”, 并打开连接SqlConnectionsqlCnt=newSqlConnection(connectString);sqlCnt.Open();使用完成后,需要关闭“连接对象”sqlCnt.Close();4、SqlCommand 对象命名空间:System.Data.SqlClient.SqlCommand;SqlCommand 对象用于执行数据库操作,操作方式有 三种: SQL 语 句 : command.CommandType = CommandType.Text; 存 储 过 程 : command.CommandType = CommandType.StoredProcedure; 整 张 表 : command.CommandType = CommandType.TableDirect;实例化一个 SqlCommand 对象SqlCommand command = new SqlCommand();command.Connection = sqlCnt; / 绑定SqlConnection 对象或直接从 SqlConnection 创建SqlCommand commandsqlCnt.CreateCommand();常用方法:command.ExecuteNonQuery(): 返回受影响函数,如增、删、改操作; command.ExecuteScalar():执行查询,返回首行首列的结果; command.ExecuteReader() : 返 回 一 个 数 据 流(SqlDataReader 对象)。常用操作 执行 SQLSqlCommand cmd = conn.CreateCommand();/创建 SqlCommand 对象cmd.CommandType = CommandType.Text; cmd.CommandText = select * from products = ID; /sql 语句 cmd.Parameters.Add(ID, SqlDbType.Int);cmd.ParametersID.Value给参数sql语句的参数赋值 调用存储过程SqlCommand cmd = conn.CreateCommand(); cmd.CommandTypeSystem.Data.CommandType.StoredProcedure;cmd.CommandText = 存储过程名; 整张表SqlCommand cmd = conn.CreateCommand(); cmd.CommandTypeSystem.Data.CommandType.TableDirect; cmd.CommandText = 表名5、SqlDataReader 对象命名空间:System.Data.SqlClient.SqlDataReader;SqlDataReader 对象提供只读单向数据的功能,单向: 只能依次读取下一条数据;只读: DataReader 中的 数据是只读的,不能修改;相对地DataSet中的数据 可以任意读取和修改.它有一个很重要的方法,是Read(),返回值是个布尔 值,作用是前进到下一条数据,一条条的返回数据, 当布尔值为真时执行,为假时跳出。如SqlCommand command = new SqlCommand();command.Connection = sqlCnt; command.CommandType = CommandType.Text; command.CommandText = Select * from Users;SqlDataReader reader = command.ExecuteReader();执行 SQL ,返回一个“流”while (reader.Read()Console.Write(readerusername); / 打印出每个用户的用户名6、DataSet 对象6.1 SqlDataAdapter;命名空间:System.Data.SqlClient.SqlDataAdapter;SqlDataAdapter 是 SqlCommand 和 DataSet 之间的桥梁,实例化 SqlDataAdapter 对象:SqlConnectionsqlCntnewSqlConnection(connectString);sqlCnt.Open();/ 创建 SqlCommandSqlCommand mySqlCommand = newSqlCommand();mySqlCommand.CommandTypeCommandType.Text;mySqlCommand.CommandText = select * fromproduct;mySqlCommand.Connection = sqlCnt;/ 创建 SqlDataAdapterSqlDataAdapter myDataAdapter = new SqlDataAdapter();myDataAdapter.SelectCommand = mySqlCommand; / 为 SqlDataAdapter 对象绑定所 要执行的 SqlCommand 对象上述SQL可以简化为SqlConnectionsqlCnt=newSqlConnection(connectString);sqlCnt.Open();/ 隐藏了 SqlCommand 对象的定义,同时隐藏了SqlCommand 对象与 SqlDataAdapter 对象的绑定SqlDataAdapter myDataAdapter = newSqlDataAdapter(select * from product, sqlCnt);属性和方法 myDataAdapter.SelectCommand属 性 :SqlCommand 变量,封装 Select 语句; myDataAdapter.InsertCommand属 性 :SqlCommand 变量,封装 Insert 语句; myDataAdapter.UpdateCommand属 性 :SqlCommand 变量,封装 Update 语句; myDataAdapter.DeleteCommand属 性 :SqlCommand 变量,封装 Delete 语句。myDataAdapter.fill()将执行结果填充到 Dataset 中,会隐藏打开 SqlConnection 并执行 SQL 等操作。6.2 SqlCommandBuilder;命名空间: System.Data.SqlClient.SqlCommandBuilder。对 DataSet 的操作(更改、增加、删除)仅是在本地 修改,若要提交到“数据库”中则需要 SqlCommandBuilder 对象。用于在客户端编辑完数据 后,整体一次更新数据。具体用法如下: SqlCommandBuilder mySqlCommandBuilder = new SqlCommandBuilder(myDataAdapter); / 为 myDataAdapter 赋予 SqlCommandBuilder 功能 myDataAdapter.Update(myDataSet, 表 名 );II向数据库提交更改后的 DataSet,第二个参数为DataSet 中的存储表名,并非数据库中真实的表名(二 者在多数情况下一致)。6.3 DataSet命名空间:System.Data.DataSet。数据集,本地微型数据库,可以存储多张表。使用 DataSet 第一步就是将 SqlDataAdapter 返回的数据集(表)填充到 Dataset 对象中:SqlDataAdapter myDataAdapter = newSqlDataAdapter(select * from product, sqlCnt);DataSet myDataSet = new DataSet(); / 创 建DataSet myDataAdapter.Fill(myDataSet, product); / 将返 回的数据集作为“表”填入 DataSet 中,表名可以与数 据库真实的表名不同,并不影响后续的增、删、改等 操作 访问 DataSet 中的数据SqlDataAdapter myDataAdapter = new SqlDataAdapter(select * from product, sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, product);DataTable myTable = myDataSet.Tablesproduct; foreach (DataRow myRow in myTable.Rows) foreach (DataColumn myColumn in myTable.Columns) Console.WriteLine(myRowmyColumn); / 遍历表中的每个单元格 修改 DataSet 中的数据SqlDataAdapter myDataAdapter = new SqlDataAdapter(select * from product, sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, product);/ 修改 DataSetDataTable myTable = myDataSet.Tablesproduct; foreach (DataRow myRow in myTable.Rows) myRowname = myRowname + 商品;/ 将 DataSet 的修改提交至“数据库” SqlCommandBuilder mySqlCommandBuilder = new SqlCommandBuilder(myDataAdapter);myDataAdapter.Update(myDataSet, product);注意:在修改、删除等操作中表 product 必须定义主 键,select的字段中也必须包含主键,否则会提示“对 于不返回任何键列信息的 SelectCommand,不支持UpdateCommand 的动态 SQL 生成。”错误 增加一行SqlDataAdapter myDataAdapter = new SqlDataAdapter(select * from product, sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, product);DataTable myTable = myDataSet.Tablesproduct;/ 添加一行DataRow myRow = myTable.NewRow();myRowname = 捷安特;myRowprice = 13.2;/myRowid = 100; id 若为“自动增长”,此处可以不 设置,即便设置也无效 myTable.Rows.Add(myRow);/将DataSet的修改提交至“数据库”SqlCommandBuilder mySqlCommandBuilder = newSqlCommandBuilder(myDataAdapter);myDataAdapter.Update(myDataSet, product); 删除一行SqlDataAdapter myDataAdapter = new SqlDataAdapter(select * from product, sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, product);/ 删除第一行DataTable myTable = myDataSet.Tablesproduct;myTable.Rows0.Delete();SqlCommandBuilder mySqlCommandBuilder = newSqlCommandBuilder(myDataAdapter);myDataAdapter.Update(myDataSet, product);属性Tables :获取包含在DataSet中的表的集合。Relations :获取用于将表链接起来并允许从父表浏览 到子表的关系的集合。HasEroors :表明是否已经初始化DataSet对象的值。方法Clear清除DataSet对象中所有表的所有数据。Clone复制DataSet对象的结构到另外一个DataSet 对象中,复制内容包括所有的结构、关系和约束,但 不包含任何数据。Copy 复制 DataSet 对象的数据和结构到另外一个DataSet 对象中。两个 DataSet 对象完全一样。CreateDataReader 为每个 DataTable 对象返回带有 个结果集的DataTableReader ,顺序与Tables集 合中表的显示顺序相同。Dispose 释放 DataSet 对象占用的资源。Reset 将 DataSet 对象初始化。7、释放资源资源使用完毕后应及时关闭连接和释放,具体方法如 下:myDataSet.Dispose();/ 释放 DataSet 对象myDataAdapter.Dispose();/ 释 放SqlDataAdapter 对象myDataReader.Dispose();/ 释 放SqlDataReader 对象sqlCnt.Close();/ 关闭数据库连接sqlCnt.Dispose();象/ 释放数据库连接对学生戌绩管理粟统-Microsoft Visual StudioFor ml ,cs文件旧精Q O S3代码设计器助姑鞋方勰器曰CtrkAlt-bLg団认蚩源管理器皿CtrlACtrl+IVIK服爲谡源勰啦Ctrl i-Alt+S悟SQL Server对盖蛍源晉理器CtrTTVtrl-hSA凋用层次结梅CLDCtrl4-Alt-bK令类视胃回Ctrl-l-Shift+匚n代裔口CtrlA D豹对鲂览馳CtrkAlt-b&普議奏CtrkX. E輸二團Ctrl-h Alt-hO视圉凹 项目曰 生成 调试樹 gkM工具(I用 F2O:右刹新(E)DelAl BAAlt+Entererver 库凶(5)娠陶Oe0 Any CPU R w7 X dbagre歹冋十Form1. 时-K匹主趣edf 衰r血魅号首理实 b鱷 E同义词逸師集 4 Azure k ? KSWg 21S53P :卜同沙P 逊I* 良桶添加连接) 刨建新sqAs,測虫!)输入敢帰產的文件名WindowsO SQL Se啟沖? XeaJ0E0 :Microson SQL Server(SqlGient)gft(Q.谿瑟心歸心壬朋:另TFiW宓侥fig“1个引用、lxr-h k将bl将 码Ta码 * 4 1 i J IX ah iT E服务器思好库实验m出性(R)Q)添加新表(T)Alt-f-Enter*Udbo.Toble (住汁)k XForml.cs怎妙ISdbo.歟弓色芒羨(対)怎占如(设计idIM鳴类型列名/ ft(i)汞华住傩ClusteCHECK 约康(0)丟引(0)權越如10)Q it N “ s T-SQLCREATE TABLE dbo. Table文件(F)峯辑 fts(v)顶目)生成 耐D)afM)休希级g 测试 分忻O * 血 2 出 A Debug Any CPU宙口 CW) Sfc(H)侈改玫据“识SSSl允讦Null欧认值rOIdXint注85賈近“设计惨改逐“dbo. 表 fi视因命存僦 矽b 舷恒 逊Del新建(Q)分离琳库(D在SQL Server尢舷波厘性中淡览固Alt+EnterTABLE dbo. Taiueoug * nny vhu r ewj w -:修改Jg.修S3E cs ifti+Jdbo.KvSSS XJSJForml.cs连接用的字符串(主銘 Clustered: Id)(0)2 ir= Null就认铉IE TABLE dbo. Table
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑环境 > 建筑资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!