C#动态创建数据库

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ADOX;

namespace WfpApp
{
    /// <summary>
    /// 创建库需要添加COM引用:Microsoft ADO Ext. 2.8 for DDL and Security
    /// 创建数据表需要添加COM引用:Microsoft ActiveX Data Objects 2.8 Library
    /// </summary>
    public class DynamicAccess
    {

        public DynamicAccess(string local)
        {
            _DbPath = local;
        }

        private string _DbPath;
        /// <summary>
        /// ACCESS数据库路径,包含文件名称
        /// </summary>
        public string DbPath
        {
            get { return _DbPath; }
            set { _DbPath = value; }
        }


        private string _strErrorInfo;
        /// <summary>
        /// 获取异常信息
        /// </summary>
        /// <returns></returns>
        public string GetStrErrorInfo()
        {
            return _strErrorInfo;
        }

        /// <summary>
        /// 动态创建ACCESS
        /// </summary>
        /// <returns></returns>
        public bool CreateAccess()
        {
            try
            {
                ADOX.Catalog catalog = new ADOX.Catalog();
                catalog.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + DbPath + ";Jet OLEDB:Engine Type=5");
                 return true;
            }
            catch (Exception ex)
            {
                _strErrorInfo = ex.Message;
                return false;
            }
        }


        public bool CreateTable()
        {
            try
            {

                ADOX.Catalog catalog = new ADOX.Catalog();
                //创建链接
                ADODB.Connection cn = new ADODB.Connection();
                //打开
                cn.Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + DbPath, null, null, -1);
                //激活链接
                catalog.ActiveConnection = cn;
                //创建表
                ADOX.Table table = new ADOX.Table();
                table.Name = "FirstTable";
                //创建列
                ADOX.Column column = new ADOX.Column();
                column.ParentCatalog = catalog;
                //列名称
                column.Name = "RecordId";
                //列类型
                column.Type = DataTypeEnum.adInteger;
                //默认长度
                column.DefinedSize = 9;
                //自动增长列
                column.Properties["AutoIncrement"].Value = true;
                //将列添加到表中
                table.Columns.Append(column, DataTypeEnum.adInteger, 9);
                //第一列为主键
                table.Keys.Append("FirstTablePrimaryKey", KeyTypeEnum.adKeyPrimary, column, null, null);
                table.Columns.Append("CustomerName", DataTypeEnum.adVarWChar, 50);
                table.Columns.Append("Age", DataTypeEnum.adInteger, 9);
                table.Columns.Append("Birthday", DataTypeEnum.adDate, 0);
                catalog.Tables.Append(table);

                cn.Close();

                return true;
            }
            catch (Exception ex)
            {
                _strErrorInfo = ex.Message;
                return false;
            }

        }

    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值