C# Access 数据库 操作

using System;
using System.IO;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.OleDb;
using System.Windows.Forms;

namespace MyProjectDAL
{
    public class AccessDB
    {
        private OleDbConnection connection;
        private string connectionString;

        //构造函数
        public AccessDB()
        {
            string path = Application.ExecutablePath;
            FileInfo exeInfo = new FileInfo(path);
            path = exeInfo.DirectoryName + "\\";
            connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path + "user data\\database\\MyProject.mdb";
            connection = new OleDbConnection(connectionString);
        }


        //打开连接
        private bool OpenConnection()
        {
            try
            {
                connection.Open();
                return true;
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库连接失败 ErrorCode: " + (ex.ErrorCode).ToString());
                return false;
            }
        }


        //关闭连接
        private bool CloseConnection()
        {
            try
            {
                connection.Close();
                return true;
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("关闭数据库失败 ErrorCode: " + (ex.ErrorCode).ToString());
                return false;
            }
        }

        //执行插入语句
        public bool Insert(String strInsert)
        {
            string query = strInsert;
            try
            {
                if (this.OpenConnection() == true)
                {
                    OleDbCommand cmd = new OleDbCommand(query, connection);
                    cmd.ExecuteNonQuery();
                    this.CloseConnection();
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库操作失败 ErrorCode: " + (ex.ErrorCode).ToString());
                return false;
            }
        }


        //执行更新语句
        public bool Update(String strUpdate)
        {
            string query = strUpdate;
            try
            {
                if (this.OpenConnection() == true)
                {
                    OleDbCommand cmd = new OleDbCommand();
                    cmd.CommandText = query;
                    cmd.Connection = connection;
                    cmd.ExecuteNonQuery();
                    this.CloseConnection();
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库更新失败 ErrorCode: " + (ex.ErrorCode).ToString());
                return false;
            }
        }


        //执行删除语句
        public bool Delete(String sql)
        {
            string query = sql;
            try
            {
                if (this.OpenConnection() == true)
                {
                    OleDbCommand cmd = new OleDbCommand(query, connection);
                    cmd.ExecuteNonQuery();
                    this.CloseConnection();
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库操作失败 ErrorCode: " + (ex.ErrorCode).ToString());
                return false;
            }
        }


        //执行查询语句
        public DataTable Query(string strQuery)
        {
            string query = strQuery;
            DataTable dt = new DataTable();
            try{
                if (this.OpenConnection() == true)
                {
                    OleDbDataAdapter da = new OleDbDataAdapter(query, connection);
                    da.Fill(dt);
                 }
                this.CloseConnection();
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库操作失败 ErrorCode: " + (ex.ErrorCode).ToString());
            }
            return dt;  
        }


        //执行查询计数语句
        public int Count(string strCount)
        {
            string query = strCount;
            int Count = -1;
            try
            {
                if (this.OpenConnection() == true)
                {
                    OleDbCommand cmd = new OleDbCommand(query, connection);
                    Count = int.Parse(cmd.ExecuteScalar().ToString());
                    this.CloseConnection();
                }
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库操作失败 ErrorCode: " + (ex.ErrorCode).ToString());
            }
            return Count;
        }

        //执行求和语句
        public double Sum(string strSum)
        {
            string query = strSum;
            double Sum = 0.0;
            try
            {
                if (this.OpenConnection() == true)
                {
                    OleDbCommand cmd = new OleDbCommand(query, connection);
                    Sum = double.Parse(cmd.ExecuteScalar().ToString());
                    this.CloseConnection();
                }
            }
            catch (OleDbException ex)
            {
                MessageBox.Show("数据库操作失败 ErrorCode: " + (ex.ErrorCode).ToString());
            }
            return Sum;
        }

        //transaction process
        public bool RunTransaction(string[] strQuerys)
        {
            if (strQuerys.Length > 0)
            {
                try
                {
                    OleDbCommand cmd = new OleDbCommand();
                    cmd.Connection = this.connection;
                    OleDbTransaction transaction = null;
                    if (this.OpenConnection() == true)
                    {
                        transaction = connection.BeginTransaction();
                        cmd.Transaction = transaction;
                        for (int i = 0; i < strQuerys.Length; i++)
                        {
                            cmd.CommandText = strQuerys[i];
                            cmd.ExecuteNonQuery();
                        }
                        transaction.Commit();
                        this.CloseConnection();
                        return true;
                    }
                    else
                    {
                        return false;
                    }
                }
                catch (OleDbException ex)
                {
                    MessageBox.Show("数据库操作失败 ErrorCode: " + (ex.ErrorCode).ToString());
                    return false;
                }
            }
            else
            {
                return false;
            }
        }
///
    }
}

本文介绍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
发出的红包

打赏作者

_老杨_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值