EnterpriseLibrary数据访问 使用存储过程访问数据库

2023-10-19 08:58

本文主要是介绍EnterpriseLibrary数据访问 使用存储过程访问数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

演示代码下载: http://dev.mjxy.cn/a-entlib-Access-the-database-using-stored-procedures.aspx

使用存储过程访问数据库

 

1.配置文件

view sourceprint?
01<configuration>
02  <configSections>
03    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=5.0.414.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" requirePermission="true" />
04  </configSections>
05  <dataConfiguration defaultDatabase="QuickStarts Instance" />
06  <connectionStrings>
07    <add name="QuickStarts Instance" connectionString="Database=EntLibQuickStarts;Server=(local);Integrated Security=SSPI;"
08      providerName="System.Data.SqlClient" />
09  </connectionStrings>
10</configuration>

2.程序代码

view sourceprint?
01// TODO: Use Enterprise Library Data Block
02using Microsoft.Practices.EnterpriseLibrary.Data;
03using Microsoft.Practices.EnterpriseLibrary.Common.Configuration;
04   
05     // TODO: Create private field for Database
06        private Database _db = EnterpriseLibraryContainer.Current.GetInstance<Database>("QuickStarts Instance");
07   
08        private void MainForm_Load(object sender, System.EventArgs e)
09        {
10            this.cmbCategory.Items.Clear();
11   
12            // TODO: Use a DataReader to retrieve Categories
13            using (IDataReader rd = _db.ExecuteReader("GetCategories"))
14            {
15                while (rd.Read())
16                {
17                    Category item = new Category(
18                        rd.GetInt32(0),
19                        rd.GetString(1),
20                        rd.GetString(2)
21                        );
22                    this.cmbCategory.Items.Add(item);
23                }
24            }
25   
26            if (this.cmbCategory.Items.Count > 0)
27                this.cmbCategory.SelectedIndex = 0;
28        }
29   
30        private void cmbCategory_SelectedIndexChanged(object sender, System.EventArgs e)
31        {
32            this.dsProducts.Clear();
33   
34            Category selectedCategory = (Category) this.cmbCategory.SelectedItem;
35            if (selectedCategory == null)
36                return;
37   
38            // TODO: Retrieve Products by Category
39     //将存储过程返回的表填充到DataSet 使用表名products,selectedCategory.CategoryID是参数
40            _db.LoadDataSet("GetProductsByCategory",
41                this.dsProducts, new string[] { "products" },
42                selectedCategory.CategoryId);
43   
44        }
45   
46        private void btnSave_Click(object sender, System.EventArgs e)
47        {
48            // TODO: Use the DataSet to update the Database 
49            System.Data.Common.DbCommand insertCommand = null;
50            insertCommand = _db.GetStoredProcCommand("HOLAddProduct");
51            _db.AddInParameter(insertCommand, "ProductName", DbType.String, "ProductName", DataRowVersion.Current);
52            _db.AddInParameter(insertCommand, "CategoryID", DbType.Int32, "CategoryID", DataRowVersion.Current);
53            _db.AddInParameter(insertCommand, "UnitPrice", DbType.Currency, "UnitPrice", DataRowVersion.Current); 
54              
55            System.Data.Common.DbCommand deleteCommand = null
56            deleteCommand = _db.GetStoredProcCommand("HOLDeleteProduct"); 
57            _db.AddInParameter(deleteCommand, "ProductID", DbType.Int32, "ProductID", DataRowVersion.Current); 
58            _db.AddInParameter(deleteCommand, "LastUpdate", DbType.DateTime, "LastUpdate", DataRowVersion.Original); 
59              
60            System.Data.Common.DbCommand updateCommand = null; updateCommand = _db.GetStoredProcCommand("HOLUpdateProduct"); 
61            _db.AddInParameter(updateCommand, "ProductID", DbType.Int32, "ProductID", DataRowVersion.Current); 
62            _db.AddInParameter(updateCommand, "ProductName", DbType.String, "ProductName", DataRowVersion.Current); 
63            _db.AddInParameter(updateCommand, "CategoryID", DbType.Int32, "CategoryID", DataRowVersion.Current);
64            _db.AddInParameter(updateCommand, "UnitPrice", DbType.Currency, "UnitPrice", DataRowVersion.Current);
65            _db.AddInParameter(updateCommand, "LastUpdate", DbType.DateTime, "LastUpdate", DataRowVersion.Current); 
66              
67            int rowsAffected = _db.UpdateDataSet(this.dsProducts, "Products"
68                insertCommand, updateCommand, deleteCommand, UpdateBehavior.Standard);
69   
70              
71        }

这篇关于EnterpriseLibrary数据访问 使用存储过程访问数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/238751

相关文章

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的