Access

using System;
using System.Data.OleDb;
using System.Data;
using System.Windows.Forms;
using System.IO;
using ADODB;
using ADOX;


namespace DB
{
    class AccessDBUtil
    {
        private static string fileName = "";

        static string str_url = "";
        private static String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + str_url;

        private AccessDBUtil()
        {

        }
        //判断数据库是否存在,如果不存在则创建数据库
        public static void checkDBExists()
        {
            if (!File.Exists(str_url))
            {

                Catalog catalog = new Catalog();
                try
                {
                    catalog.Create(connectionString);

                    //连接数据库
                    ADODB.Connection cn = new ADODB.Connection();
                    cn.Open(connectionString, null, null, -1);
                    catalog.ActiveConnection = cn;
                    CreateParaOpDB(catalog,"tableName");
             
                    catalog = null;
                    cn.Close();
                }
                catch(Exception ex)
                {

                    Console.WriteLine(ex);
                }
            }
        }

        
 
  
        private static void CreateParaOpDB(Catalog catalog,string tableName)
        {

            Table table = new Table();
            table.Name = tableName;

            Column column = new Column();
            column.ParentCatalog = catalog;
            column.Type = ADOX.DataTypeEnum.adInteger; // 必须先设置字段类型
            column.Name = "ID";
            column.DefinedSize = 8;
            column.Properties["AutoIncrement"].Value = true;
            table.Columns.Append(column, ADOX.DataTypeEnum.adInteger, 0);
          
            table.Columns.Append("Num", ADOX.DataTypeEnum.adVarWChar, 120);
            table.Columns.Append("DateTime", ADOX.DataTypeEnum.adVarWChar, 120);
    


            try
            {
                catalog.Tables.Append(table);
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex);
           
            }
            //此处一定要关闭连接,否则添加数据时候会出错
            table = null;
            Application.DoEvents();
        }

      
        public static DataSet ExecuteQuery(string sql)
        {
            return ExecuteQuery(sql, null);
        }
        //执行查询语句,返回dataset
        public static DataSet ExecuteQuery(string sql, OleDbParameter[] parameters)
        {
            //Debug.WriteLine(sql);
            using (OleDbConnection connection = new OleDbConnection(connectionString))
            {
                DataSet ds = new DataSet();
                try
                {
                    connection.Open();

                    OleDbDataAdapter da = new OleDbDataAdapter(sql, connection);
                    if (parameters != null) da.SelectCommand.Parameters.AddRange(parameters);
                    da.Fill(ds, "ds");
                }
                catch (Exception ex)
                {
                      Console.WriteLine(ex);
                }
                return ds;
            }
        }
        public static int ExecuteInsert(string sql)
        {
            return ExecuteInsert(sql, null);
        }
        //执行单条插入语句,并返回id,不需要返回id的用ExceuteNonQuery执行。
        public static int ExecuteInsert(string sql, OleDbParameter[] parameters)
        {
            Console.WriteLine(sql);

            using (OleDbConnection connection = new OleDbConnection(connectionString))
            {
                OleDbCommand cmd = new OleDbCommand(sql, connection);
                try
                {
                    connection.Open();
                    if (parameters != null) cmd.Parameters.AddRange(parameters);
                    cmd.ExecuteNonQuery();
                    cmd.CommandText = @"select @@identity";
                    int value = Int32.Parse(cmd.ExecuteScalar().ToString());
                    return value;
                }
                catch (Exception e)
                {
                          Console.WriteLine(ex);
                    throw e;
                }
            }
        }

    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老汉憨憨1

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

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

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

打赏作者

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

抵扣说明:

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

余额充值