YBB.DBUtils用法
通用数据访问类库,兼容ADO、ADO.NET方式访问。
利用ProviderFactory工厂方法,支持Oracle(不需要安装客户端)、SQL Server、OleDb和ODBC等数据库访问。
https://github.com/BobinYang/YBB.DBUtils
用法:
1、初始化线程缓存AdoNetHelper 类:
- Oracle:
using (AdoNetHelper Db = AdoNetHelper.ThreadInstance("data source=:1521/orcl;user id=;password=*;", DbProviderType.Oracle_ManagedODP))) { 。。。。。 }
- SQL Server:
using (AdoNetHelper Db = AdoNetHelper.ThreadInstance("data source=;user id=sa;password=;Initial Catalog=*;", DbProviderType.SqlServer))) { 。。。。。 }//Dispose可关闭所有内部连接。
2、常用的命令:
- Db.OpenNewConnection()
- Db.CreateNewCommand(sql, conn)
- Db.BeginNewTrans(conn)
- Db.CreateNewCommand(sql, trans);
- Db.MakeInParam(":a", **)
- DataSet ds = Db.ExecuteDataset(conn, "GetOrders", 24, 36);
以及所有DbHelper中的方法。
3、打开连接和创建命令,执行读数据
举例:
string sql = "select 1 from **";
DbConnection conn = null;
try
{
conn = Db.OpenNewConnection();
DbCommand command = Db.CreateNewCommand(sql, conn);
DbDataReader dr = command.ExecuteReader(); // Convert.ToInt32(command.ExecuteScalar()); // DataTable dt1 = Db.ExecuteDataset(command);
if (rd.HasRows)
{
dr.Close();
return true;
}
// while (dr.Read())
//{
// List1.Add(dr[0].ToString().Trim());
// }
dr.Close();
}
finally
{
Db.CloseConnection(conn);
}
4、带参数执行命令
举例:
sql = "insert into table1 (column1,column2) values (:a,:b)";//sql server为@符号
DbConnection conn = Db.Conn;
using (DbCommand command = Db.CreateNewCommand(sql, conn))
{
command.Parameters.Add(Db.MakeInParam(":a", **));
command.Parameters.Add(Db.MakeInParam(":b", **));
command.ExecuteNonQuery();
}
5、利用事务处理更新操作。
int rows = ;
DbConnection conn = Db.OpenNewConnection();
DbTransaction trans = Db.BeginNewTrans(conn);
DbCommand command = Db.CreateNewCommand(sql, trans);
try
{
sql = "delete **";
command.CommandText = sql;
rows = command.ExecuteNonQuery(); sql = "update **";
command.CommandText = sql;
rows = command.ExecuteNonQuery(); trans.Commit();
}
catch (Exception)
{
if (trans != null)
{
trans.Rollback();
}
throw;
}
return rows;
6、插入操作返回最新值。
string lastId = "";
DbTransaction trans = null;
try
{
DbConnection conn = Db.Conn;
trans = Db.BeginNewTrans(conn); sql = "insert intotable1 (column1,column2) values (*,*) RETURNING ID into :recid "; command = Db.CreateNewCommand(sql, trans);
DbParameter paralastId = Db.MakeOutParam(":recid", DbType.String, );
paralastId.Direction = ParameterDirection.ReturnValue;
command.Parameters.Add(paralastId); command.ExecuteNonQuery();
command.Parameters.Clear();
lastId = paralastId.Value.ToString(); trans.Commit();
}
catch (Exception)
{
if (trans != null)
{
trans.Rollback();
}
throw;
}
//SQL的存储过程
ALTER PROCEDURE [dbo].[MouldFiles_Exists]
@ID int
AS
DECLARE @TempID int
SELECT @TempID = count(1) FROM [MouldFiles] WHERE ID=@ID
IF @TempID = 0
RETURN 0
ELSE
RETURN 1
7、处理存储过程的输入输出参数。
string sql = "sp***";
DbConnection conn = Db.Conn;
command = Db.CreateNewCommand(sql, conn);
command.CommandType = CommandType.StoredProcedure; //钻取存储过程参数
DbParameter[] spParameterSet = Db.GetSpParameterSet(sql); //参数加入到command中
foreach (DbParameter parameter in spParameterSet)
{
command.Parameters.Add(parameter);
} //为参数赋值
command.Parameters[":line"].Value = Line;
command.Parameters[":model"].Value = PartNumber; command.ExecuteNonQuery();
//得到输出参数的值(@ID int output,)
ID = Convert.ToInt32(((OracleDecimal)(command.Parameters[":ID"].Value)).Value);
command.Parameters.Clear();
command.CommandType = CommandType.Text;
8、类图如下:

YBB.DBUtils用法的更多相关文章
- 第14天dbutils与案例
第14天dbutils与案例 第14天dbutils与案例 1 1. 1.dbutils介绍 2 2. 2.dbutils快速入门 2 3. 3.dbutils A ...
- xUtils介绍 -- DbUtils、ViewUtils、HttpUtils、BitmapUtils
转载注明出处:https://github.com/wyouflf/xUtils xUtils简单介绍 xUtils 包括了非常多有用的android工具. xUtils 支持大文件上传,更全面的ht ...
- Android 最热的高速发展框架XUtils
近期搜了一些框架供刚開始学习的人学习,比較了一下XUtils是眼下git上比較活跃 功能比較完好的一个框架,是基于afinal开发的,比afinal稳定性提高了不少.以下是介绍: 鉴于大家的热情,我又 ...
- Android框架之高速开发框架xUtil
做Android开发我们通常是从原生态的開始,就是调用默认那些Android代码来开发我们的应用,可是到了一定程度,我们就想着怎么来高速开发我们的应用.这个时候我们就要着手来研究框架了. 以下介绍一个 ...
- android高速开发框架xUtils
xUtils简单介绍 xUtils 包括了非常多有用的android工具. xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词).拥有更加灵活的ORM,很多其它的事件注解支持且不受 ...
- Android 最火的高速开发框架xUtils
Github下载地址:https://github.com/wyouflf/xUtils xUtils简单介绍 xUtils 包括了非常多有用的Android工具. xUtils 最初源于Afinal ...
- 强大的xUtils工具类整理
xUtils简单介绍 xUtils 包括了非常多有用的android工具. xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,很多其它的事件注解支持且不受 ...
- 为什么要使用数据库连接池?以及用法(DBUtils)
看代码, from flask import Flask from db import POOL import pymysql app = Flask(__name__) app.secret_key ...
- xUtils中用DbUtils,ViewUtils的用法
一.有关xUtils的简介 xUtils 包含了很多实用的android工具.xUtils 最初源于Afinal框架,进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持(10 ...
随机推荐
- Linux中Redis的安装
一.下载redis redis官网地址:http://www.redis.io/ 下载地址:http://download.redis.io/releases/ redis中文文档地址:http:// ...
- tr循环,每行 2个数相加 求出和位第三个数赋值 (http://jsfiddle.net/hgeL44rz/113/)
<table id="tb"> <tr> <th>单价</th> <th>数量</th> <th> ...
- emberjs 循环中设置model的不同属性值
//var grades = ['1', '2', '3', '4', '7', '8', '9']; ']; grades.forEach(function (item) { App.Templat ...
- ASP.NET 预编译笔记
本来下写篇总结,但感觉自己语言不知道怎么组织.就算了. aspnet_compiler的问题: 一开始 aspnet_compiler -v \ -p F: E: -fixednames e ...
- 解决post请求乱码问题
将下面配置信息配置在webapp/WEB-INF/web.xml中 <!-- 解决post乱码 --><filter> <filter-name>Character ...
- vue+element ui 的表格列使用组件
前言:工作中用到 vue+element ui 的前端框架,有这个场景:很多表格的列有许多一样的,所以考虑将列封装为组件.转载请注明出处:https://www.cnblogs.com/yuxiaol ...
- Java提供了哪些IO方式?IO, BIO, NIO, AIO是什么?
IO一直是软件开发中的核心部分之一,而随着互联网技术的提高,IO的重要性也越来越重.纵观开发界,能够巧妙运用IO,不但对于公司,而且对于开发人员都非常的重要.Java的IO机制也是一直在不断的完善,以 ...
- COGS2608 [河南省队2016]无根树
传送门 这题大概就是传说中的动态树形DP了吧,学习了一波…… 首先,对于没有修改的情况,不难想到树形DP,定义$f_i$表示强制必须选$i$且只能再选$i$的子树中的点的最优解,易得转移方程$f_i= ...
- 日历视图(CalendarView)
日历视图(Calendarview) 常用属性: android:selectedWeekBackgroundColor(设置被选中周的背景颜色) android:showWeekNumber(设置是 ...
- 关于jsp页面中时间显示问题
首先说明一下情况,在MySQL数据库中获取的时间显示在jsp页面中不是按指定格式显示,显示的是类似于这种--Tue Jun 18 00:00:00 CST 2013.而想要的仅仅是年月日而已. 对于这 ...