版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、SQL 数 据 库 操 作 步 骤及代码第2章数据库高级编程ADO.NET 是为.NET 框架而创建的,是对 ADO (ActiveX Data Objects)对 象模型的扩充。ADO.NET提供了一组数据访问服务的类,可用于对MicrosoftSQL Server、Oracle等数据源的一致访问。 ADO.NET模型分为.NET Data Provider (数据提供程序)和DataSet数据集(数据处理的核心)两大主要部 分。.NET数据提供程序提供了四个核心对象,分别是Co nn ection、Comma nd、DataReade和DataAdapter对象。功能如表2-1所示。表2-
2、1 ADO.NET核心对象对象功能Connection提供和数据源的连接功能Comma nd提供访问数据库命令,执行查询数据或修改数据的功能,例如 运行SQL命令和存储过程等DataReader从数据源中读取只向前的且只读的数据流DataAdapter是DataSet对象和数据源间的桥梁。DataAdapter使用4个Comma nd对象来运行查询、新建、修改、删除的 SQL命令,把数据力n载到 DataSet丿 或者把 DataSet内的数据送冋数据源2.1 SQL Server相关配置在使用C#访问数据库之前,首先创建一个名为“ chap2'的数据库,此数据库 作为2.1节及2.2
3、节中例题操作的默认数据库。然后创建数据表 Products,表结 构如表2-2所示。创建完毕后可录入初始化数据若干条。表2-2 Products表表结构序号列名字段说明数据类型长度主键允许空1ProductID商品编号char4主键否2ProductName商品名称nvarchar40否3SupplierName供应商名称nvarchar40否4CategoryName商品类别名称nvarchar40否5UnitPrice单价money否6UnitsInStock库存量smallint否7Discount是否折扣char1否F面首先介绍几个SQL Server 2012的常用操作。这些操作都是
4、初学者在实践环节及上机课的操作中出现问题较多的地方。1 身份验证方式SQL Server 2012在安装时默认是使用 Windows验证方式的,但是安装过后 用户可随时修改身份验证方式。启动SQL Server 2012 Management Studio在“连接到服务器”对话框中选择Windows身份验证”连接服务器,连接成功后,在窗体左侧的“对象资源管理器” 中右键单击服务器实例节点,并在弹出的快捷菜单中选择“属性”菜单项,系统 将弹出“服务器属性”窗体,切换至“安全性”选项卡,如图-1所示。图2-1 “服务器属性”对话框-“安全性”选项卡在“服务器身份验证”部分选择SQL Server和
5、Windows身份验证模式”选项, 并单击【确定】按钮。系统将提示需要重新启动 SQL Server以使配置生效,如 图2-2所示。图2-2系统提示框右键单击“对象资源管理器”的服务器实例节点,在弹出的快捷菜单中选择“重新启动”菜单项,SQL Server将重新启动服务,重启成功后即可使用混合验 证方式登录SQL Server服务器。2 添加登录账户大部分初学者都习惯于使用 SQL Server的系统管理员账号“sa”来登录数据库 服务器,而在实际工作环境中使用 sa账号登录服务器是不合理的。因为很多情 况下系统的数据库是部署在租用的数据库服务器上的,此时数据库设计人员或 编程人员都不可能具有
6、sa账号的使用权限,因此在将身份验证方式修改为SQLServer和Windows混合验证后,需要为某应用程序创建一个专用的登录账户。 其操作步骤描述如下。(1)使用Windows身份验证登录SQL Server,在对象资源管理器中点击“安全性”节点前面的加号+”,在展开后的“登录名”子节点上单击右键,如图2-3所示,并在弹出的快捷菜单中选择“新建登录名”选项图2-3登录名节点的右键菜单(2) 系统弹出“登录名一新建”对话框中,如图2-4所示。首先在登录名输入框中填写需要创建的用户名,此处以“ zd”为例;将身份验证方式选为SQLServer身份验证”,为新建账户设置密码为“ 123”,同时去除
7、“强制实施密码策略” 和“用户在下次登录时必须更改密码”选项;最后为账户选择默认数据库“hap2'。图2-4“登录名-新建”对话框“常规”选项卡(3)服务器角色节点不予配置。有关 SQL Server服务器角色请参考相关资 料,此处不再详细介绍。(4)在对话框左侧选项卡中选择“用户映射”节点,如图2-5所示,在“映射 到此登录名的用户”列表中,勾选此前创建好的数据库“ chap2',在窗体右下方的“数据库角色成员身份”框里选择db_Owner”,即数据库拥有者。图2-5“登录名-新建”对话框“用户映射”选项卡(5)安全对象节点一般不予配置。(6)在对话框左侧选项卡中选择“状态”
8、节点,如图2-6所示,将“是否允许连接到数据库引擎”选项设为“授予”,同时将“登录”选项设为“启用”。以上各节点 配置完成后单击【确定】按钮,即完成了对账户的创建工作图2-6“登录名-新建”对话框“状态配置”选项卡(7)新建账户完成后,重新连接 SQL Server,如图2-7所示,选择SQLServer身份验证方式,输入前面设置的登录名“ zd”及密码123”,点击【连接】按钮,即可完成登录。登录成功后在对象资源管理器中可看到服务器实例名后 面显示的登录用户名,如图2-8所示SQL Server :二土tjI出逛名獻RSf t4J.Id-曲口mAWfH14BJJ»图2-8对象资源管
9、理器图2-7 “连接到服务器”对话框2.2使用ADO.NET访问数据库2.2.1连接数据库在对数据源进行操作之前,首先需建立到数据源的连接,可使用Conn ection对象显式创建到数据源的连接。【例2-1】 设计一个 Windows应用程序,能通过“Windows验证“和Windows和SQL Server混合验证”两种方式建立到数据库的连接。图2-9 “连接数据库”窗体控件 Tab顺序实现过程如下。(1)新建一 Windows应用程序,命名为connection,将创建的默认窗体名 更名为frmConnect,窗体的Text属性设置为“连接数据库”,界面设计如图2-9 所示。frmConn
10、ect窗体中的主要控件,按Tab键顺序,描述如表2-3所示。表2-3 “连接数据库”窗体控件及说明Tab顺序控件类型控件名称说明主要属性属性名属性值0ButtonbtnConnect1Windows身份验证方式连接数据库TextWindows 验证1btnConnect2混合验证方式连接数据库Text混合验证(2)主要程序代码说明:本节内所有例题代码均需引用 System.Data.SqlClient命名空间,代码如下:using System.Data.SqlClient; /添加对 SQL Server 数据访问对象的引用后续例题不再逐一说明。 由于篇幅所限,本节中所有例题的异常捕获代码都
11、省略了,读者需自行添加获取控件输入及访问数据库等处的异常捕获代码。双击【Win dows验证】按钮,进入其 Click事件处理函数,代码如下:/Windows方式连接数据库private void btnConnect1_Click(object sender, EventArgs e)string strConn = "server=XP-4;database=chap2;integrated security=true" / 连接字符串SqlConnection conn = new SqlConnection(strConn); / 创建连接对象conn.Open()
12、;/ 打开连接/如连接成功则弹岀消息框提示MessageBox.Show(”数据库已通过集成验证方式连接成功",”连接状态对话框");conn.Close();/使用完毕后关闭数据库连接双击【混合验证】按钮,进入其 Click事件处理函数,填写代码如下。/SQL Server + Windows方式连接数据库private void btnConnect2_Click(object sender, EventArgs e)string strConn = "server=XP-4.;database=chap2;uid=zd;pwd=123" / 连接字
13、符串SqlConnection conn = new SqlConnection(strConn); / 创建连接对象conn.Open(); / 打开连接/如连接成功则弹岀消息框提示MessageBox.Show(”数据库已通过混合验证方式连接成功",”连接状态对话框");conn.Close();/使用完毕后关闭数据库连接数据库连接字符串包含要连接的数据库的信息,如server属性指定数据库服务器名称,database属性指定数据库名称,使用Win dows身份验证方式只需要给出server和 database两个属性的值,并使用“ integrated securit
14、y=true"指定身 份验证方式为 Windows验证;当使用混合验证时则需要使用uid属性指定数据库账户、pwd属性指定该账号的密码。说明:上例中的连接字符串中的用户名“ zd”和密码“3”,是以本节“添加登 录账户”的方式创建的,读者可自行修改为自己计算机的SQLServer登录名及密运行程序,分别单击【Windows验证】和【混合验证】两个按钮,如连接成功,将分别弹出不同的连接状态对话框,如图2-10所示兀粧疋嵐二庄阪荃二石77宜实疋H唏 盂E團曲諂驻皿式垂接就口图2-10连接状态对话框222对数据库进行添加、修改及删除操作在创建好到数据库的连接之后,可以使用Comma nd对
15、象对数据库进行更新操作。【例2-2】设计一个Windows应用程序,能实现对数据库表的添加、修改 及删除操作。实现过程:(1)新建一 Windows应用程序,命名为operateData将创建的默认窗体名更名为frmCommand,窗体的Text属性设置为“对数据库执行添加、修改及删 除操作”,界面设计如图2-11所示。frmCommand窗体中的主要控件,按Tab键 顺序,描述如表2-4所示。图2-11“对数据库进行添加、修改及删除操作”窗体Tab顺序视图表2-4 “对数据库执行添加、修改及删除操作”窗体控件及说明Tab顺序控件类型控件名称说明主要属性属性名属性值0Buttonbtnlnse
16、rt向数据库表添加一条记录Text添加1btnUpdate修改数据库表中的记录Text修改2btnDelete删除数据库表中的记录Text删除(2)主要程序代码 双击【添加】按钮,进入其 Click事件处理函数,代码如下。/【添加】按钮单击事件处理函数private void btnlnsert_Click(object sender, EventArgs e)string strConn = "server=XP-4;database=chap2;integrated security=true" / 连接字符串SqlConnection conn = new SqlCo
17、nnection(strConn); / 声明并创建连接对象conn.Open(); /打开数据库连接/向商品表插入一条新记录string strSql="insert into Products values('0012','双层蒸锅苏泊尔集团','厨具',129.9,100,'false')"SqlCommand comm = new SqlCommand(strSql, conn); / 声明并创建命令对象int row = comm.ExecuteNonQuery(); /执行SQL语句,并获取受影响的
18、行数if (row > 0) /如果记录插入成功,则弹出消息框提示MessageBox.Show(”插入数据成功","操作状态对话框”);conn.Close(); /关闭数据库连接 双击【修改】按钮,进入其 Click事件处理函数,代码如下。/【修改】按钮单击事件处理函数private void btnUpdate_Click(object sender, EventArgs e)string strConn = "server=XP-4;database=chap2;integrated security=true"SqlConnection
19、conn = new SqlConnection(strConn);conn.Open();/修改商品表中的一条记录string strSql = "update Products set UnitsInStock=500 where ProductlD='0012";SqlCommand comm = new SqlCommand(strSql, conn);int row = comm.ExecuteNonQuery();if (row > 0)MessageBox.Show(”修改数据成功","操作状态对话框”);conn.Close
20、(); 双击【删除】按钮,进入其 Click事件处理函数,代码如下。/【删除】按钮单击事件处理函数private void btnDelete_Click(object sender, EventArgs e)string strConn = "server=XP-4;database=chap2;integrated security=true"SqlConnection conn = new SqlConnection(strConn);conn.Open();/删除商品表中的一条记录string strSql = "delete from Products
21、where ProductID='0012'"SqlCommand comm = new SqlCommand(strSql, conn);int row = comm.ExecuteNonQuery();if (row > 0)MessageBox.Show(”删除数据成功",”操作状态对话框");conn.Close();运行程序,分别单击【添加】、【修改】和【删除】按钮,如操作成功, 将分别弹出不同的操作状态对话框,如图2-12所示。对于数据库记录的修改情况,读者可同时从SQL Server管理控制台访问数据库chap2的Product
22、s表进行 验证。損作状态对话框斗图2-12操作状态对话框2.2.3查询数据库中的数据【例2-3】设计一个 Windows应用程序,使用DataReade查询数据库中的信息并加载到ComboBox控件的选项中。实现过程:(1)新建一 Windows应用程序,命名为testDataReade,将创建的默认窗体名更名为frmProducts,窗体的Text属性设置为“商品类别及名称”,界面设计如图2-13所示。frmProducts窗体中的主要控件,按Tab键顺序,描述如表2-5 所示。图2-13 “商品类别及名称”窗体 Tab键顺序视图表2-5“商品类别及名称”窗体控件及说明Tab顺序控件类型控件
23、名称说明主要属性属性名属性值0ComboBoxcomboCategory所有商品类别名称DropDownStyleDropDownList1comboProducts某商品类别下的商品名称DropDownStyleDropDownList说明:界面中不参与编程的Label控件不再进行说明,以下各例题均同样处(2)主要程序代码双击窗体标题栏,进入Load事件处理函数,访问数据库,为“商品类别”下拉框加载数据,代码如下/窗体加载事件处理函数,为“商品类别”组合框加载所有的商品类别数据private void frmProducts_Load(object sender, EventArgs e)s
24、tring strConn = "server=XP-4;database=chap2;integrated security=true" 连接字符串SqlConnection conn = new SqlConnection(strConn); / 声明并创建连接对象conn.Open(); /打开数据库连接string strSql = "select distinct CategoryName from Products" / 查询SqlCommand comm = new SqlCommand(strSql, conn);SqlDataReade
25、r dr = comm.ExecuteReader();while (dr.Read()comboCategory.ltems.Add(drO); / 依次加载数据项至 ComboBoxdr.Close();conn.Close();双击商品类别下拉框,进入其 Selected In dexCha nge(事件处理函数,根据其选项为“商品名称”下拉框加载数据,代码如下/ “商品类别”下拉框选项索引变化事件处理函数,/根据商品类别下拉框中的选项加载该类别下的所有的商品名称private void comboCategory_SelectedlndexChanged(object sender,
26、EventArgs e)comboProducts.ltems.Clear();string strConn = "server=XP-4;database=chap2;integrated security=true"SqlConnection conn = new SqlConnection(strConn);conn.Open();string strSql = "select ProductName from Products where CategoryName="'+comboCategory.Text+""
27、9; SqlCommand comm = new SqlCommand(strSql, conn);SqlDataReader dr = comm.ExecuteReader();while (dr.Read()comboProducts.ltems.Add(drO);dr.Close(); conn.Close();【例2-4】使用DataAdaper和 DataSet对象查询数据库中的信息并加载到ComboBox控件的选项中。实现过程:(1) 新建一 Windows应用程序,命名为dataSe,将创建的默认窗体名更名为frmProducts,窗体及各主要控件的属性设置同例2-3。(2) 主
28、要程序代码 双击窗体标题栏,进入其Load事件处理函数,访问数据库,为“商品类别”下拉框加载数据,代码如下。窗体加载事件处理函数,为“商品类别”组合框加载所有的商品分类数据。private void frmProducts_Load(object sender, EventArgs e)string strConn = "server=XP-4;database=chap2;integrated security=true" / 连接字符串SqlConnection conn = new SqlConnection(strConn); / 声明并创建连接对象string s
29、trSql = "select distinct CategoryName from Products" / 查询不重复的商品类别名称 SqlDataAdapter da = new SqlDataAdapter(strSql, conn); / 声明并创建数据适配器对象DataSet ds = new DataSet(); /声明并创建数据集对象da.Fill(ds); /使用数据适配器填充数据集comboCatagory.DataSource = ds.Tables0; / 设置商品类别下拉框数据源 comboCatagory.DisplayMember = "
30、;CategoryName" / 设置商品类别下拉框的显示属性 双击“商品类别”下拉框,进入其SelectedI ndexCha nge(事件处理函数,根据其选中项为“商品名称”下拉框加载数据,代码如下。/ “商品类别”下拉框选项索引变化事件处理函数,/根据商品类别下拉框中的选项加载该类别下的所有的商品名称private void comboCatagory_SelectedlndexChanged(object sender, EventArgs e)string strConn = "server=XP-4;database=chap2;integrated secur
31、ity=true"SqlConnection conn = new SqlConnection(strConn);根据“商品类别”下拉框中的选项查询商品名称string strSql="select ProductName from Products where CategoryName="'+comboCategory.Text+""'SqlDataAdapter da = new SqlDataAdapter(strSql, conn);DataSet ds = new DataSet();da.Fill(ds);combo
32、Products.DataSource = ds.TablesO; / 设置商品名称下拉框的数据源 comboProducts.DisplayMember = "ProductName" / 设置商品名称下拉框的显示属性思考:细心的同学会发现,例2-3和例2-4虽然运行界面完全相同,但是窗 体加载之后列表框中选项的情况是有区别的。那么,区别在哪呢?原因又是什 么呢?2.2.4数据绑定控件【例2-5】设计一个Windows应用程序,能实现商品信息的维护。本例题中,程序要读取数据库中的数据,加载数据至ListBox和ComboBox控件,并根据用户在ListBox控件中选择的数
33、据项再次访问数据库,获取相关记录。另 外,本例题还实现了对商品表Products的增加、修改及删除操作。图2-14“商品信息管理”窗体 Tab键顺序视图实现过程:(1)新建一 Windows应用程序,命名为products,将创建的默认窗体名更名为frmProducts,窗体的Text属性设置为“商品信息管理”,界面设计如图2-14所示。frmProducts窗体中的主要控件,按Tab键顺序,描述如表2-6所示表2-6 “商品信息管理”窗体控件及说明Tab顺序控件类型控件名称说明主要属性属性名属性值0TextBoxtxtID输入和显示商品编号ReadonlyTrue1txtName输入和显示商
34、品名称ReadonlyTrue2txtSupplier输入和显示供应商名称ReadonlyTrue3ComboBoxcomboCategory输入和显示商品类别EnabledFalse4TextBoxtxtUnitPrice输入和显示商品单价ReadonlyTrue5txtUnitsInStock输入和显示库存数量ReadonlyTrue6CheckBoxchkDisc输入和显示是否打折EnabledFalse7ButtonbtnInsert添加商品EnabledTrue8btnUpdate修改商品EnabledTrue9btnSave保存数据EnabledFalse10btnCancle取消
35、编辑EnabledFalse11btnDelete删除数据EnabledTrue12ListBoxlstProducts商品名称列表EnabledTrue(2)主要程序代码首先要为该程序添加两个成员变量,代码如下:string strConn = "server=XP-4;database=chap2;integrated security=true" / 连接字符串string insertORupdate = ""/标识变量,用来记录要保存的是添加还是修改操作自定义方法DataLoad(),访问数据库,加载商品类别列表及商品名称列表,代码如下。/ &
36、lt;summary>/访问数据库,加载商品类别列表及商品名称列表/ </summary>void DataLoad()/以下代码使用DataReader访问数据库SqlConnection conn = new SqlConnection(strConn); / 创建连接对象conn.Open();/ 打开连接string strSql = "select distinct CategoryName from Products" / 查询不重复的商品类别名 SqlCommand comm = new SqlCommand(strSql, conn); /
37、 声明并创建命令对象 SqlDataReader dr = comm.ExecuteReader(); / 执行查询,用 DataReader 存放数据 while (dr.Read()/如果查询到数据comboCategory.ltems.Add(drO); / 逐项加载商品类别名至ComboBoxdr.Close();/ 关闭 dataReader/以下代码使用DataAdapter和DataSet访问数据库strSql = "select ProductName,ProductlD from Products" / 查询商品名称及商品编号SqlDataAdapter
38、da = new SqlDataAdapter(strSql, conn); / 声明并创建数据适配器对象DataSet ds = new DataSet(); 声明并创建数据集对象da.Fill(ds); /填充数据集IstProducts.DataSource = ds.TablesO; / 设置商品名称列表的数据源IstProducts.DisplayMember = "ProductName" / 设置显示值属性IstProducts.ValueMember = "ProductID" / 设置实际值属性 conn.Close();/ 关闭连接I
39、stProducts.Selectedlndex = -1; /使商品名称列表没有选中项商品管理窗体的Load事件处理函数,就是调用 DataLoad()方法,代码如下。/窗体加载事件处理函数private void frmProducts _Load(object sender, EventArgs e)DataLoad();声明自定义方法controlEnabled(),控制各输入控件在“查看”和“编辑”操作时的可用性,代码如下。/自定义方法,控制控件的可用性,将控件可用性分为查看”和编辑”两种状态public void controlEnabled(string status)if (s
40、tatus = "show") /当前为查看数据状态,控件都不可编辑btnInsert.Enabled = true;btnUpdate.Enabled = true;btnSave.Enabled = false;btnCancle.Enabled = false;btnDelete.Enabled = true;chkDisc.Enabled = false;comboCategory.Enabled = false;foreach (Control c in this.Controls)if (c is TextBox)TextBox txtb = (TextBox)
41、c);txtb.ReadOnly = true;else 当前为编辑数据状态,控件可用btnInsert.Enabled = false;btnUpdate.Enabled = false;btnSave.Enabled = true;btnCancle.Enabled = true;btnDelete.Enabled = false;chkDisc.Enabled = true;comboCategory.Enabled = true;foreach (Control c in this.Controls)if (c is TextBox)TextBox txtb = (TextBox)c)
42、;txtb.ReadOnly = false; 双击lstProducts控件,进入其选项索引变化事件处理函数,根据选择的商品,查询该商品其他信息,并为界面其他控件赋值,代码如下。/商品名称列表选项索引变化事件,根据选择的商品名称加载商品其他信息private void lstProducts_SelectedlndexChanged(object sender, EventArgs e)/用来判断用户是否选中了有效的选项,且保证是数据加载后用户进行的操作if (IstProducts.Selectedlndex != -1)&&(lstProducts.SelectedVal
43、ue.ToString()!="System.Data.DataRowView")string proId = lstProducts.SelectedValue.ToString(); / 获取当前选中商品的商品编号SqlConnection conn=new SqlConnection(strConn); / 声明并创建连接对象conn.Open();/打开数据库连接string strSql="select * from Products where Productld="'+prold+""' /由商品编号查询
44、该商品其他信息SqlCommand comm=new SqlCommand(strSql,conn); / 声明并创建命令对象SqlDataReader dr = comm.ExecuteReader(); /使用 DataReader获取查询结果if (dr.Read() /如果查询到数据,就将该商品各字段的值赋予窗体各控件用以显示txtID.Text = dr"P roductlD".ToString();txtName.Text=dr"ProductName".ToString();txtSupplier.Text=dr"Supplier
45、Name".ToString();comboCategory.Text = dr"CategoryName".ToString(); txtUnitPrice.Text=dr"UnitPrice".ToString(); txtUnitslnStock.Text=dr"UnitslnStock".ToString(); chkDisc.Checked = (dr"Discount".ToString()="True"?true:false;dr.Close(); / 关闭 DataRe
46、aderconn.Close(); / 关闭连接controlEnabled("show"); /将控件设置为查看状态说明:由于为ListBox控件加载选项时会触发SelectedlndexChangec事件, 此时获取到的 ListBox.SelectedValue.ToString()值为System.Data.DataRowView”,而不是经用户选择过的商品编号,程序需过滤掉这种情况。只有完成ListBox控件的选项加载后,经用户选择某条商品数据时,程序才进行后续操作,如下代码即可实现这种过滤功能。if (IstProducts.Selectedlndex != -
47、1)&& (lstProducts.SelectedValue.ToString()!="System.Data.DataRowView")双击btnInsert按钮,进入其Click事件处理函数,清空所有输入控件并使其为可编辑状态,设置编辑状态为insert,真正的插入操作在btnSave的Click事件处理函数中进行。代码如下/【添加】按钮单击事件处理函数private void btnlnsert_Click(object sender, EventArgs e) insertORupdate = "insert" /设置标识变量为
48、添加操作 controlEnabled("edit"); /将控件设置为编辑状态/清空所有控件foreach (Control c in this.Controls)if (c is TextBox)TextBox txtb = (TextBox)c);txtb.Text ="" comboCategory.SelectedIndex = -1; chkDisc.Checked = false;双击btnUpdate按钮,进入其Click事件处理函数,使各输入控件为可编 辑状态,设置编辑状态为update,真正的修改操作在btnSave的Click事件处
49、理 函数中进行。代码如下。/【修改】按钮单击事件处理函数private void btnUpdate_Click(object sender, EventArgs e)controlEnabled("edit");txtID.ReadOnly = true; /商品编号不能修改 insertORupdate = "update" /设置标志变量为修改操作双击btnSave按钮,进入其Click事件处理函数,根据编辑状态对数据库进行insert或update操作,代码如下。I /【保存】按钮单击事件处理函数,完成添加和修改操作private void bt
50、nSave_Click(object sender, EventArgs e)SqlConnection conn = new SqlConnection(strConn); / 声明并创建连接对象conn.Open(); /打开数据库连接下面一段代码将保存添加的商品数据if (insertORupdate = "insert")string strSql = "insert into Products values(ProductlD,ProductName ,SupplierName,CategoryName,UnitPrice,UnitslnStock,Di
51、scount)"SqlCommand comm = new SqlCommand(strSql, conn); comm.Parameters.Add(new SqlParameter("ProductID", txtID.Text); comm.Parameters.Add(new SqlParameter("ProductName", txtName.Text); comm.Parameters.Add(new SqlParameter("SupplierName", txtSupplier.Text); comm.Pa
52、rameters.Add(new SqlParameter("CategoryName", comboCategory.Text); comm.Parameters.Add(new SqlParameter("UnitPrice", float.Parse(txtUnitPrice.Text); comm.Parameters.Add(new SqlParameter("UnitslnStock", float.Parse(txtUnitslnStock.Text); comm.Parameters.Add(new SqlParame
53、ter("Discount", (chkDisc.Checked = true ? "1" : "0"); if (comm.ExecuteNonQuery() > 0)MessageBox.Show(”添加商品信息成功!");elseMessageBox.Show(”添加商品信息失败!");下面一段代码将保存修改的商品数据elsestring strSql = "update Products set ProductName=ProductName, SupplierName=SupplierNa
54、me,CategoryName=CategoryName,UnitPrice=UnitPrice, UnitslnStock=UnitslnStock,Discount=Discount where ProductID=ProductID"SqlCommand comm = new SqlCommand(strSql, conn); comm.Parameters.Add(new SqlParameter("ProductID", txtID.Text); comm.Parameters.Add(new SqlParameter("ProductName
55、", txtName.Text); comm.Parameters.Add(new SqlParameter("SupplierName", txtSupplier.Text); comm.Parameters.Add(new SqlParameter("CategoryName", comboCategory.Text); comm.Parameters.Add(new SqlParameter("UnitPrice", float.Parse(txtUnitPrice.Text); comm.Parameters.Add
56、(new SqlParameter("UnitsInStock", float.Parse(txtUnitslnStock.Text); comm.Parameters.Add(new SqlParameter("Discount", (chkDisc.Checked = true ? "1" : "0"); if (comm.ExecuteNonQuery() > 0)MessageBox.Show("更新商品信息成功!");elseMessageBox.Show("更新商品信
57、息失败!");conn.Close(); /关闭数据库连接DataLoad(); /重新访问数据库,刷新界面显示的商品信息controlEnabled("show"); /将控件设置为查看状态说明:代码中出现的SqIParamete类为SQL命令对象类。命令对象可使用参数来将值传递给SQL语句或存储过程,提供类型检查和验证。与命令文本不同,参数输入被视为文本值,而不是可执行代码。这样可帮助抵御“SQL注入”攻击,这种攻击的攻击者会将命令插入SQL语句,从而危及服务器的安 全。一般来说,在更新 DataTable或是DataSet时,如果不采用 SqIParamete, 那么当输入的Sql语句出现歧义时,如字
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 45151-2024城市配送网络体系建设指南
- GB/T 29301-2024静电复印(包括多功能)设备用鼓粉盒
- 二零二五版出租车投资入股及品牌拓展合同3篇
- 二零二五年建筑工程安全施工协议书范本3篇
- 2024甲乙双方就新产品研发项目所签订的技术秘密保护合同
- 2024版合作社商用物业租赁协议范本版B版
- 二零二五年能源公司股份代持与能源项目合作协议3篇
- 2024辽宁事业单位聘用合同书
- 2024版场地租赁协议书模板
- 二零二五年道路运输安全生产责任合同3篇
- 供销合同(完整版)
- 二零二五年企业存单质押担保贷款合同样本3篇
- 锅炉安装、改造、维修质量保证手册
- 油气行业人才需求预测-洞察分析
- (2024)河南省公务员考试《行测》真题及答案解析
- 1000只肉羊养殖基地建设项目可行性研究报告
- 《劳保用品安全培训》课件
- 2024版房屋市政工程生产安全重大事故隐患判定标准内容解读
- 2024院感年终总结报告
- 高一化学《活泼的金属单质-钠》分层练习含答案解析
- 04S206自动喷水与水喷雾灭火设施安装图集
评论
0/150
提交评论