[C#]AccessUtils
关键代码:
using System;
using System.Data;
using System.Data.OleDb;
namespace CSharpUtilHelpV2
{
/// <summary>
/// 基于.NET 2.0的ACCESS数据简单操作类
/// </summary>
public class AccessUtilsV2
{
string ConnectString = string.Empty;
/// <summary>
/// 构造函数
/// </summary>
/// <param name="path">access路径</param>
public AccessUtilsV2(string path)
{
ConnectString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path;
}
/// <summary>
/// 构造函数
/// </summary>
/// <param name="path">access路径</param>
/// <param name="password">access密码</param>
public AccessUtilsV2(string path, string password)
{
ConnectString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path + ";Jet OLEDB:Database Password= " + password;
}
/// <summary>
/// ExecuteNonQuery
/// </summary>
/// <param name="sql">查询,修改,删除sql语句</param>
/// <param name="parameters">OleDbParameter参数;eg: new OleDbParameter("@categoryName","Test2")</param>
/// <returns>操作影响行数</returns>
public int ExecuteNonQuery(string sql, OleDbParameter[] parameters)
{
int _affectedRows = -1;
using (OleDbConnection sqlcon = new OleDbConnection(ConnectString))
{
sqlcon.Open();
using (OleDbCommand sqlcmd = new OleDbCommand(sql, sqlcon))
{
if (parameters != null)
sqlcmd.Parameters.AddRange(parameters);
_affectedRows = sqlcmd.ExecuteNonQuery();
}
}
return _affectedRows;
}
/// <summary>
/// ExecuteReader
/// </summary>
/// <param name="sql">读取sql语句</param>
/// <param name="parameters">OleDbParameter参数;eg: new OleDbParameter("@categoryName","Test2")</param>
/// <returns>IDataReader</returns>
public IDataReader ExecuteReader(string sql, OleDbParameter[] parameters)
{
OleDbConnection _sqlcon = new OleDbConnection(ConnectString);
using (OleDbCommand _sqlcmd = new OleDbCommand(sql, _sqlcon))
{
if (parameters != null)
_sqlcmd.Parameters.AddRange(parameters);
_sqlcon.Open();
return _sqlcmd.ExecuteReader(CommandBehavior.CloseConnection);
}
}
/// <summary>
/// ExecuteDataTable
/// </summary>
/// <param name="sql">读取sql语句</param>
/// <param name="parameters">OleDbParameter参数;eg: new OleDbParameter("@categoryName","Test2")</param>
/// <returns>DataTable</returns>
public DataTable ExecuteDataTable(string sql, OleDbParameter[] parameters)
{
using (OleDbConnection _sqlcon = new OleDbConnection(ConnectString))
{
using (OleDbCommand _sqlcmd = new OleDbCommand(sql, _sqlcon))
{
if (parameters != null)
_sqlcmd.Parameters.AddRange(parameters);
using (OleDbDataAdapter _sqldap = new OleDbDataAdapter(_sqlcmd))
{
DataTable _dt = new DataTable();
_sqldap.Fill(_dt);
return _dt;
}
}
}
}
/// <summary>
/// ExecuteScalar
/// </summary>
/// <param name="sql">查询第一行第一列数据值</param>
/// <param name="parameters">OleDbParameter参数;eg: new OleDbParameter("@categoryName","Test2")</param>
/// <returns>Object</returns>
public Object ExecuteScalar(string sql, OleDbParameter[] parameters)
{
using (OleDbConnection _sqlcon = new OleDbConnection(ConnectString))
{
using (OleDbCommand _sqlcmd = new OleDbCommand(sql, _sqlcon))
{
if (parameters != null)
_sqlcmd.Parameters.AddRange(parameters);
_sqlcon.Open();
return _sqlcmd.ExecuteScalar();
}
}
}
}
}
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }测试代码:
using CSharpUtilHelpV2;
using System;
using System.Data;
using System.Data.OleDb;
using System.IO;
namespace CSharpUtilHelpV2Test
{
public class AccessUtilsV2Test
{
static AccessUtilsV2 AccessHelper = new AccessUtilsV2(string.Format(@"{0}\DB\Northwind.MDB", AppDomain.CurrentDomain.BaseDirectory.ToString()));
public static void ShowAccessPath()
{
string _fullPath = string.Format(@"{0}\DB\Northwind.MDB", AppDomain.CurrentDomain.BaseDirectory.ToString());
Console.WriteLine(_fullPath);
Console.WriteLine("File.Exist:" + File.Exists(_fullPath));
}
public static void ExecuteNonQueryTest()
{
//-------------------------方式一---------------------------------------
//string _sql = "INSERT INTO Categories (CategoryID, CategoryName, Description) VALUES (22, 'Test', '测试')";
//Console.WriteLine("ExecuteNonQueryTest:" + AccessHelper.ExecuteNonQuery(_sql, null));
//-------------------------方式二---------------------------------------
string _sql = "INSERT INTO Categories (CategoryID, CategoryName, Description) VALUES (@id, @categoryName, @description)";
OleDbParameter[] _paramter = new OleDbParameter[] {
new OleDbParameter("@id",23),
new OleDbParameter("@categoryName","Test2"),
new OleDbParameter("@description","测试2")
};
Console.WriteLine("ExecuteNonQueryTest:" + AccessHelper.ExecuteNonQuery(_sql, _paramter));
}
public static void ExecuteReaderTest()
{
string _sql = "select * from Categories where CategoryID<=5";
using (IDataReader reader = AccessHelper.ExecuteReader(_sql, null))
{
while (reader.Read())
{
Console.WriteLine("CategoryID:" + reader["CategoryID"] + " CategoryName:" + reader["CategoryName"]);
}
}
}
public static void ExecuteDataTableTest()
{
string _sql = "select * from Categories where CategoryID<=5";
Console.WriteLine("ExecuteDataTableTest:" + AccessHelper.ExecuteDataTable(_sql, null).Rows.Count);
}
public static void ExecuteScalarTest()
{
string _sql = "select * from Categories where CategoryID<=5";
Console.WriteLine("ExecuteScalarTest:" + AccessHelper.ExecuteScalar(_sql, null) ?? "Null");
}
}
}
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }测试结果:

这里是对Access操作的简单封装,希望有所帮助!
本人才疏学浅,难免错误,敬请指出,谢谢!
[C#]AccessUtils的更多相关文章
- .net(C#)在Access数据库中执行sql脚本
自己写的一个工具类,主要是业务场景的需要. 主要有两个功能: ①执行包含sql语句的字符串 ②执行包含sql语句的文件 调用方式 /// <summary> /// 执行sql语句 /// ...
- HBase实践案例:知乎 AI 用户模型服务性能优化实践
用户模型简介 知乎 AI 用户模型服务于知乎两亿多用户,主要为首页.推荐.广告.知识服务.想法.关注页等业务场景提供数据和服务, 例如首页个性化 Feed 的召回和排序.相关回答等用到的用户长期兴趣特 ...
随机推荐
- 基础笔记(二)HTTP协议
GET与POST的区别 1.GET提交的数据会放在URL之后,以?分割URL和传输数据,参数之间用&连接:POST是把提交的数据放在HTTP的body中. 2.GET提交的数据大小有限制(协议 ...
- 1020. Tree Traversals (25)
the problem is from pat,which website is http://pat.zju.edu.cn/contests/pat-a-practise/1020 and the ...
- VC6.0代码移植到VS2008运行时乱码问题解决
转载:http://blog.sina.com.cn/s/blog_6d0cbb030101a3cs.html 问题描述: 之前用VC6.0写过一个OpenGL的程序,后来需要将其放到VS20 ...
- MySQL的数据库引擎的类型及区别
MySQL的数据库引擎的类型 你能用的数据库引擎取决于mysql在安装的时候是如何被编译的.要添加一个新的引擎,就必须重新编译MYSQL.在缺省情况下,MYSQL支持三个引擎:ISAM.MYISAM和 ...
- 让 BAT 的 Offer 不再难拿
随着各大公司春招的开始,很多小伙伴都行动起来了,我有幸能够加入百度并和大家分享自己的经验心得.由于我面试的都是比较大的公司,所以自然也是做了这方面的准备,因此这篇总结并不一定适合想去创业公司的同学.另 ...
- DataBase 之 常用操作
(1) try catch 配合 Transactions 使用 --打开try catch功能 set xact_abort on begin try begin tran ) commit tra ...
- 模拟游客一天的生活与旅游java程序代写源码
在某个城市的商业区里,有一家首饰店,一家饭店,一家面馆,一家火锅店,一家银行,一家当铺 现在有一群来自四川的游客,一群陕西的游客,一群上海的游客,和以上各店家的工作人员在此区域里,请模拟他们一天的生活 ...
- [辛酸历程]在Mac中使用Python获取屏幕截图
一.起因 最近想做个小外挂玩玩,技术倒是不难,就是通过图片匹配加上一些判断方法来刷分.但是在最不起眼(却最容易出问题)的准备阶段卡住了. 为什么卡住了呢,简单说,因为我需要获取截屏的数据,所以就要找一 ...
- 8张图带你理解Java整个只是网络(转载)
8张图带你理解Java整个只是网络 一图胜千言,下面图解均来自Program Creek 网站的Java教程,目前它们拥有最多的票选.如果图解没有阐明问题,那么你可以借助它的标题来一窥究竟. 1.字符 ...
- The Story of self Parameter in Python, Demystified
转自:http://www.programiz.com/article/python-self-why If you have been programming in Python (in obj ...