C# 应用程序类中定义ACCESS数据库文件地址的方法

本文介绍了两种在C#中操作ACCESS数据库的方法:一种是通过定义数据库连接字符串并使用OleDb进行数据库操作;另一种是根据应用程序类型(Windows或类库)动态设定数据库路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C# 应用程序类中定义ACCESS数据库文件地址的方法
方法一:
数据库访问类
using System;
using System.Collections.Generic;
using System.Text;
using System.Data.OleDb;
using System.Data;

namespace Link.DataBase
{
public class DBManage
{
System.Data.OleDb.OleDbConnection gConn = null;

public OleDbConnection Conn
{
get { return gConn; }
}
//定义类公开对外的数据库连接对象变量
static string strConnectionString;
//设置数据链接参数
static public string ConnectionString
{
set
{
strConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + value + ";User ID=admin;Password=;Jet OLEDB:Database Password=";
}
}

//数据库连接对象
public DBManage()
{
gConn = new OleDbConnection(strConnectionString);
}
//查询数据库资料
public OleDbDataReader ExecuteReader(string SQL)
{
OleDbDataReader reValue = null;
OleDbCommand comm = new OleDbCommand();
comm.CommandText = SQL;
comm.Connection = gConn;
reValue = comm.ExecuteReader();
return reValue;
}
//执行SQL查询语句返回数据表对象
public DataTable ExecuteTable(string SQL)
{
DataTable table = new DataTable();
gConn.Open();
OleDbCommand comm = new OleDbCommand();
comm.CommandText = SQL;
comm.Connection = gConn;
System.Data.OleDb.OleDbDataAdapter adapter = new System.Data.OleDb.OleDbDataAdapter(comm);
System.Data.OleDb.OleDbCommandBuilder commBuild = new System.Data.OleDb.OleDbCommandBuilder(adapter);
table.Locale = System.Globalization.CultureInfo.InvariantCulture;
adapter.Fill(table);
gConn.Close();
return table;
}
//直接运行输入SQL语句参数
public void ExecuteNonQuery(string SQL)
{
OleDbCommand comm = new OleDbCommand();
gConn.Open();
comm.CommandText = SQL;
comm.Connection = gConn;
comm.ExecuteNonQuery();
gConn.Close();
}

}
}
窗体调用方法

public LinksManagement()
{
DBManage.ConnectionString = Application.StartupPath + @"/ExchangeLinksDB.mdb";
InitializeComponent();
}

方法二:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.OleDb;

//数据访问层
namespace Link.DataBase
{
public class CreateUrlManager
{

private OleDbConnection cnn;

private static string strConnectionString;

public CreateUrlManager()
{
if (System.Environment.CurrentDirectory == AppDomain.CurrentDomain.BaseDirectory)//Windows应用程序则相等
{
strConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + AppDomain.CurrentDomain.BaseDirectory + "Bin//ExchangeLinksDB.mdb;";
}
else//Windows类程序不相等
{
strConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + AppDomain.CurrentDomain.BaseDirectory + "ExchangeLinksDB.mdb;";
}
}

}

本文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。 1.通过ADO.NET的OleDb相关来操作Access 主要知识点如下: using System.Data.OleDb; using System.Data; 连接字符串:String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb"; 建立连接:OleDbConnection connection = new OleDbConnection(connectionString); 使用OleDbCommand来执行Sql语句: OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery(); 2.取得Access自增标识字段在插入数据后的id值 cmd.CommandText = @"select @@identity"; int value = Int32.Parse(cmd.ExecuteScalar().ToString()); return value; 3.执行事务 需要用到OleDbTransaction,关键语句如下: OleDbConnection connection = new OleDbConnection(connectionString); OleDbCommand cmd = new OleDbCommand(); OleDbTransaction transaction = null; cmd.Connection = connection; connection.Open(); transaction = connection.BeginTransaction(); cmd.Transaction = transaction; cmd.CommandText=sql1; cmd.ExecuteNonQuery(); cmd.CommandText=sql2; cmd.ExecuteNonQuery(); transaction.Commit(); 4.执行查询,返回DataSet OleDbConnection connection = new OleDbConnection(connectionString); DataSet ds = new DataSet(); connection.Open(); OleDbDataAdapter da = new OleDbDataAdapter(sql, connection); da.Fill(ds,"ds"); 5.分页查询 分页查询使用OleDbDataReader来读取数据,并将结果写到一个DataSet中返回。 以上内容封装为三个可重用的AccessDBUtil,AccessPageUtil,Page 代码这里下载AccessDBUtilDemo.rar (191.37 KB , 下载:999次) 本例程是一个c#的winform程序,但是数据访问可以在Web环境下使用。 本例程演示了: 1.Access数据库的插入,更新,修改,查询; 2.带参数的sql语句的使用,而不是拼SQL; 3.使用DataReader的分页查询,而不是用嵌套的SQL语句来分页; 4.用事务同时执行多个SQL语句; 5.在插入数据的同时返回最新的ID值; 6.整型,实型,字符串,日期型,布尔型五种数据型的操作; 7.使用正则表达式来验证整数和实数; 8.listview用来显示数据的一些基本用法。 本示例不包括: 1.高效的分页查询,仅仅是提供了一种分页的方法,但我认为DataReader应该比嵌套的SQL语句快(未测试)。 2.完善的分页封装,只提供了分页的简单包装。 3.嵌套的事务处理,提供了同时执行多个sql语句的事务处理,但不支持嵌套事务。 4.listview的使用,只是利用winform控件来演示数据访问,因此不能作为winform编程的良好示例,例如添加数据时界面并没有很好地更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值