活动介绍

ADO.NET命令执行与数据操作全解析

立即解锁
发布时间: 2025-08-20 01:14:35 阅读量: 1 订阅数: 3
PDF

C# 5.0与SQL Server 2012数据库开发实战

### ADO.NET 命令执行与数据操作全解析 在进行数据库操作时,我们常常会用到 ADO.NET 来执行各种 SQL 命令以实现数据的查询、插入、更新和删除等操作。接下来,我们将详细探讨如何使用 ADO.NET 执行不同类型的命令,以及如何处理常见的问题。 #### 1. 使用 ExecuteScalar 方法的注意事项 在使用 `ExecuteScalar` 方法时,需要注意两个问题。一是类型转换问题,因为不能将字符串直接转换为整数。二是查询结果行数的问题,如果查询实际返回多行数据,而你原本以为只会返回一行,那么 `ExecuteScalar` 方法只会返回结果的第一行,而忽略其余行。所以,使用 `ExecuteScalar` 方法时,要确保期望并实际得到单个值的返回。 #### 2. 执行返回多结果的命令 当期望查询返回多行多列数据时,可以使用命令的 `ExecuteReader` 方法。该方法会返回一个数据读取器,即 `SqlDataReader` 类的实例。数据读取器有一些方法,可用于读取结果集中的连续行并检索单个列的值。 ##### 2.1 使用 ExecuteReader 方法的步骤 1. 选择 ADO.NET_Command 项目,右键单击,选择“添加” -> “Windows 窗体”。在打开的对话框中,确保选择“Windows 窗体”,并将 Form1.cs 重命名为 CommandReader.cs,点击“确定”将此窗体添加到 ADO.NET_Command 项目中。 2. 点击 CommandReader 窗体的标题栏选中该窗体,将“Size”属性的“Width”设置为 455,“Height”设置为 283。 3. 将一个 TextBox 控件拖到窗体上。选中此 TextBox 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 txtReader。 - 将“Location”属性的“X”设置为 12,“Y”设置为 12。 - 将“Multiline”属性设置为 True。 - 将“ScrollBars”属性设置为 Vertical。 - 将“Size”属性的“Width”设置为 415,“Height”设置为 223。 - 留空“Text”属性。 4. 现在,CommandReader 窗体的设计视图应类似于图 13 - 5。 5. 双击 CommandReader.cs 窗体的空白区域,将打开代码编辑器窗口,显示 CommandReader_Load 事件。将 CommandReader_Load 事件修改为如下代码: ```csharp Using System.Data.SqlClient; private void CommandReader_Load(object sender, EventArgs e) { // Create connection SqlConnection conn = new SqlConnection(@" server = .\sql2012; integrated security = true; database = AdventureWorks"); // Create command string sql = @"select Name,ProductNumber from Production.Product"; SqlCommand cmd = new SqlCommand(sql, conn); txtReader.AppendText("Command created and connected.\n\n"); try { // Open connection conn.Open(); // Execute query via ExecuteReader SqlDataReader rdr = cmd.ExecuteReader(); while (rdr.Read()) { txtReader.AppendText("\nProduct: "); txtReader.AppendText(rdr.GetValue(1) + "\t\t" + rdr.GetValue(0)); txtReader.AppendText("\n"); } } catch (SqlException ex) { MessageBox.Show(ex.Message + ex.StackTrace, "Exception Details"); } finally { conn.Close(); txtReader.AppendText("Connection Closed."); } } ``` 6. 要将 CommandReader 窗体设置为启动窗体,修改 Program.cs 语句: ```csharp Application.Run(new CommandScalar ()); ``` 为: ```csharp Application.Run(new CommandReader()); ``` 构建项目,然后按 Ctrl + F5 运行。 7. 当窗体加载时,结果应类似于图 13 - 6。 ##### 2.2 ExecuteReader 方法的工作原理 在这个示例中,使用 `ExecuteReader` 方法检索并输出 Production.Product 表中所有产品的 Name 和 ProductNumber 值。与 `ExecuteScalar` 方法一样,`ExecuteReader` 方法会获取 CommandText 属性,并使用 Connection 属性中的连接将其发送到数据库。当使用 `ExecuteScalar` 方法时,只会产生单个标量值;而使用 `ExecuteReader` 方法会返回一个 SqlDataReader 对象。SqlDataReader 对象有一个 `Read` 方法,用于依次获取每一行,还有一个 `GetValue` 方法,用于获取行中某一列的值。要检索其值的特定列由表示列索引的整数参数指定。请注意,`GetValue` 使用从零开始的索引,因此第一列是列 0,第二列是列 1,依此类推。由于查询请求了两列(Name 和 ProductNumber),因此在这个查询结果中,这两列的编号分别为 0 和 1。 #### 3. 执行非查询语句 `ExecuteNonQuery` 方法用于执行由 DML 语句组成的 SQL 语句,这些语句包括 SQL Server 的 INSERT、UPDATE 和 DELETE 功能。因此,`ExecuteNonQuery` 方法用于将 DML 语句提供给命令并执行它。如之前所注意到的,INSERT、UPDATE 和 DELETE 语句不会返回任何记录。 ##### 3.1 使用 ExecuteNonQuery 方法的步骤 1. 选择 ADO.NET_Command 项目,右键单击,选择“添加” -> “Windows 窗体”。在打开的对话框中,确保选择“Windows 窗体”,并将 Form1.cs 重命名为 CommandNonQuery.cs,点击“确定”将此窗体添加到 ADO.NET_Command 项目中。 2. 点击 CommandNonQuery 窗体的标题栏选中该窗体,将“Size”属性的“Width”设置为 297,“Height”设置为 277。 3. 将一个 GroupBox 控件拖到窗体上,并将其定位到窗体左侧。选中此 GroupBox 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 gbInsertCurrency。 - 将“Location”属性的“X”设置为 21,“Y”设置为 22。 - 将“Size”属性的“Width”设置为 240,“Height”设置为 201。 - 将“Text”属性设置为“Insert Currency”。 4. 将一个 Label 控件拖到名为 gbInsertCurrency 的 GroupBox 中,并将其定位到 GroupBox 左侧。选中此 Label 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 lblCurrencyCode。 - 将“Location”属性的“X”设置为 16,“Y”设置为 30。 - 将“Size”属性的“Width”设置为 77,“Height”设置为 13。 - 将“Text”属性设置为“Currency Code”。 5. 将一个 TextBox 控件拖到窗体上,并将其定位到名为“Currency Code”的 Label 控件旁边。选中此 TextBox 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 txtCurrencyCode。 - 将“Location”属性的“X”设置为 99,“Y”设置为 30。 - 将“Size”属性的“Width”设置为 128,“Height”设置为 20。 - 留空“Text”属性。 6. 将另一个 Label 控件拖到名为 gbInsertCurrency 的 GroupBox 中,并将其定位到“Currency Code”标签下方、GroupBox 左侧。选中此 Label 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 lblName。 - 将“Location”属性的“X”设置为 19,“Y”设置为 64。 - 将“Size”属性的“Width”设置为 35,“Height”设置为 13。 - 将“Text”属性设置为“Name”。 7. 将一个 TextBox 控件拖到窗体上,并将其定位到名为“Name”的 Label 控件旁边。选中此 TextBox 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 txtName。 - 将“Location”属性的“X”设置为 99,“Y”设置为 64。 - 将“Size”属性的“Width”设置为 128,“Height”设置为 20。 - 留空“Text”属性。 8. 此时,CommandNonQuery 窗体的设计视图应类似于图 13 - 7。 9. 继续进行窗体设计,将另一个 Label 控件拖到名为 gbInsertCurrency 的 GroupBox 上,并将其定位到“Name”标签下方、GroupBox 左侧。选中此 Label 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 lblModifiedDate。 - 将“Location”属性的“X”设置为 19,“Y”设置为 97。 - 将“Size”属性的“Width”设置为 73,“Height”设置为 13。 - 将“Text”属性设置为“Modified Date”。 10. 将一个 DateTimePicker 控件拖到窗体上,并将其定位到“Modified Date”标签控件旁边。选中此 DateTimePicker 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 dtpModifiedDate。 - 将“Format”属性设置为“Short”。 - 将“Location”属性的“X”设置为 99,“Y”设置为 97。 - 将“Size”属性的“Width”设置为 128,“Height”设置为 20。 11. 将一个 Button 控件拖到名为 gbInsertCurrency 的 GroupBox 中,并将其定位到 Label 和 TextBox 控件下方。选中此 Button 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 btnInsertCurrency。 - 将“Location”属性的“X”设置为 56,“Y”设置为 133。 - 将“Size”属性的“Width”设置为 128,“Height”设置为 23。 - 将“Text”属性设置为“Insert Currency”。 12. 将另一个 Label 控件拖到名为 gbInsertCurrency 的 GroupBox 中,并将其定位到“Insert Currency”按钮下方。选中此 Label 控件,导航到“属性”窗口,设置以下属性: - 将“Name”属性设置为 lblInsertStatus。 - 将“AutoSize”属性设置为 False。 - 将“Location”属性的“X”设置为 22,“Y”设置为 168。 - 将“Size”属性的“Width”设置为 205,“Height”设置为 21。 13. 现在,CommandNonQuery 窗体的设计视图应类似于图 13 - 8。 14. 双击“Insert Currency”按钮,将打开代码编辑器窗口,显示 btnInsertCurrency_Click 事件。将 btnInsertCurrency_Click 事件修改为如下代码: ```csharp Using System.Data.SqlClient; private void btnInsertCurrency_Click(object sender, EventArgs e) { // Create connection SqlConnection conn = new SqlConnection(@"server = .\ ```
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

SW_孙维

开发技术专家
知名科技公司工程师,开发技术领域拥有丰富的工作经验和专业知识。曾负责设计和开发多个复杂的软件系统,涉及到大规模数据处理、分布式系统和高性能计算等方面。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看

最新推荐

【Focas1_2 SDK报警处理机制精讲】:快速故障诊断与解决方案

![Focas1_2 SDK](https://media.springernature.com/lw1200/springer-static/image/art%3A10.1007%2Fs00170-021-08393-5/MediaObjects/170_2021_8393_Fig18_HTML.png) # 摘要 本文系统性地探讨了Focas1_2 SDK报警处理机制,从理论基础到实际应用,全面分析了报警机制的定义、目的、处理流程、信息存储与查询,以及实践应用中的配置管理、通知响应和数据分析。文中还详细论述了高级技巧,包括自定义处理逻辑、系统集成与扩展,以及安全性与隐私保护措施。最后,

STM8点阵屏汉字显示:用户界面设计与体验优化的终极指南

![STM8点阵屏汉字显示:用户界面设计与体验优化的终极指南](http://microcontrollerslab.com/wp-content/uploads/2023/06/select-PC13-as-an-external-interrupt-source-STM32CubeIDE.jpg) # 摘要 STM8点阵屏技术作为一种重要的显示解决方案,广泛应用于嵌入式系统和用户界面设计中。本文首先介绍STM8点阵屏的技术基础,然后深入探讨汉字显示的原理,并着重分析用户界面设计策略,包括布局技巧、字体选择、用户交互逻辑及动态效果实现等。接着,本文详细阐述了STM8点阵屏的编程实践,涵盖开

【BT-audio音频抓取工具比较】:主流工具功能对比与选择指南

# 摘要 本文旨在全面介绍BT-audio音频抓取工具,从理论基础、功能对比、实践应用到安全性与隐私保护等多个维度进行了深入探讨。通过分析音频信号的原理与格式、抓取工具的工作机制以及相关法律和伦理问题,本文详细阐述了不同音频抓取工具的技术特点和抓取效率。实践应用章节进一步讲解了音频抓取在不同场景中的应用方法和技巧,并提供了故障排除的指导。在讨论工具安全性与隐私保护时,强调了用户数据安全的重要性和提高工具安全性的策略。最后,本文对音频抓取工具的未来发展和市场需求进行了展望,并提出了选择合适工具的建议。整体而言,本文为音频抓取工具的用户提供了一个全面的参考资料和指导手册。 # 关键字 音频抓取;

飞利浦监护仪通讯协议深度剖析:构建稳定连接的关键

![飞利浦监护仪通讯协议深度剖析:构建稳定连接的关键](https://cdn.venafi.com/994513b8-133f-0003-9fb3-9cbe4b61ffeb/7e46c2ff-fe85-482d-b0ff-517c45ec1618/aid_inline_img__cae2063c76738929e4ae91ebb994147a.png?fm=webp&q=85) # 摘要 本文全面介绍了飞利浦监护仪通讯协议的概况、理论基础、协议框架解析,以及构建稳定连接的实践技巧。通过对监护仪通讯协议的原理、结构、层次、安全性及错误检测机制的深入分析,提供了在病房监护系统整合、移动医疗和医

【wxWidgets多媒体处理】:实现跨平台音频与视频播放

![【wxWidgets多媒体处理】:实现跨平台音频与视频播放](https://media.licdn.com/dms/image/D4D12AQH6dGtXzzYAKQ/article-cover_image-shrink_600_2000/0/1708803555419?e=2147483647&v=beta&t=m_fxE5WkzNZ45RAzU2jeNFZXiv-kqqsPDlcARrwDp8Y) # 摘要 本文详细探讨了基于wxWidgets的跨平台多媒体开发,涵盖了多媒体处理的基础理论知识、在wxWidgets中的实践应用,以及相关应用的优化与调试方法。首先介绍多媒体数据类型与

【企业级应用高性能选择】:View堆栈效果库的挑选与应用

![View堆栈效果库](https://cdn.educba.com/academy/wp-content/uploads/2020/01/jQuery-fadeOut-1.jpg) # 摘要 堆栈效果库在企业级应用中扮演着至关重要的角色,它不仅影响着应用的性能和功能,还关系到企业业务的扩展和竞争力。本文首先从理论框架入手,系统介绍了堆栈效果库的分类和原理,以及企业在选择和应用堆栈效果库时应该考虑的标准。随后通过实践案例,深入探讨了在不同业务场景中挑选和集成堆栈效果库的策略,以及在应用过程中遇到的挑战和解决方案。文章最后展望了堆栈效果库的未来发展趋势,包括在前沿技术中的应用和创新,以及企业

【调试与性能优化】:LMS滤波器在Verilog中的实现技巧

![【调试与性能优化】:LMS滤波器在Verilog中的实现技巧](https://img-blog.csdnimg.cn/img_convert/b111b02c2bac6554e8f57536c89f3c05.png) # 摘要 本文详细探讨了最小均方(LMS)滤波器的理论基础、硬件实现、调试技巧以及性能优化策略,并通过实际案例分析展示了其在信号处理中的应用。LMS滤波器作为一种自适应滤波器,在数字信号处理领域具有重要地位。通过理论章节,我们阐述了LMS算法的工作原理和数学模型,以及数字信号处理的基础知识。接着,文章介绍了LMS滤波器的Verilog实现,包括Verilog语言基础、模块

【评估情感分析模型】:准确解读准确率、召回率与F1分数

![Python实现新闻文本类情感分析(采用TF-IDF,余弦距离,情感依存等算法)](https://img-blog.csdnimg.cn/20210316153907487.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2xpbGRu,size_16,color_FFFFFF,t_70) # 摘要 情感分析是自然语言处理领域的重要研究方向,它涉及从文本数据中识别和分类用户情感。本文首先介绍了情感分析模型的基本概念和评估指标,然后

MATLAB程序设计模式优化:提升pv_matlab项目可维护性的最佳实践

![MATLAB程序设计模式优化:提升pv_matlab项目可维护性的最佳实践](https://pgaleone.eu/images/unreal-coverage/cov-long.png) # 摘要 本文全面探讨了MATLAB程序设计模式的基础知识和最佳实践,包括代码的组织结构、面向对象编程、设计模式应用、性能优化、版本控制与协作以及测试与质量保证。通过对MATLAB代码结构化的深入分析,介绍了函数与脚本的差异和代码模块化的重要性。接着,本文详细讲解了面向对象编程中的类定义、继承、封装以及代码重用策略。在设计模式部分,本文探讨了创建型、结构型和行为型模式在MATLAB编程中的实现与应用

【游戏物理引擎基础】:迷宫游戏中的物理效果实现

![基于C++-EasyX编写的益智迷宫小游戏项目源码.zip](https://images-wixmp-ed30a86b8c4ca887773594c2.wixmp.com/f/7eae7ef4-7fbf-4de2-b153-48a18c117e42/d9ytliu-34edfe51-a0eb-4516-a9d0-020c77a80aff.png/v1/fill/w_1024,h_547,q_80,strp/snap_2016_04_13_at_08_40_10_by_draconianrain_d9ytliu-fullview.jpg?token=eyJ0eXAiOiJKV1QiLCJh