教程中国
PHOTOSHOP CS9.0中文版 MAYA 8.5 FOR WINDOWS Corel Painter v9.0 Flash MX2004 中文版 Illustrator cs2 中文版
VC++6.0含sp6 中英文版 VB6.0 +sp6 简体中文版 Borland Delphi 7汉化版 MSDN for vb6.0中文版 Visual Studio 2005简体
教程中国下属 文件存储共享专家BIBIDU.COM 提供大型软件,教材,源码,电影,音乐,图书等下载 更多精品请点此进入
  您目前所在位置: 教程中国 >> .NET类 >> ASP.NET >> 在.NET 2.0框架下动态创建Access数据库和表 RSS订阅
在.NET 2.0框架下动态创建Access数据库和表
教程(视频,书籍)下载:  ASP.NET AutoCAD 数据库 C# ASP java photoshop 网页设计 delphi 3dmax Flash C++ VB 张孝祥 实例   更多请进入BIBIDU搜索
IT搜索引擎   
     在以前的文章《如何在.NET框架下创建Access数据库和表?》中提供的方法,在.NET 2.0下无效,所有的字段类型都变成了文本类型,不知道微软改变了什么东西。下面将修正后的代码发布如下。
  
  C#:
  
  <%@ Page Language="C#" %>
  
  <%@ Import Namespace="ADOX" %>
  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  
  <script runat="server">
   /// <summary>
   /// CreateAccessDB 的摘要说明。
   /// 对于不同版本的ADO,需要添加不同的引用
   /// 请添加引用Microsoft ADO Ext. 2.7 for DDL and Security
   /// 请添加引用Microsoft ADO Ext. 2.8 for DDL and Security
   /// </summary>
  
   protected void Page_Load(object sender, EventArgs e)
   {
   //为了方便测试,数据库名字采用比较随机的名字,以防止添加不成功时还需要重新启动IIS来删除数据库。
   string dbName = "D:\\NewMDB" + DateTime.Now.Millisecond.ToString() + ".mdb";
   ADOX.CatalogClass cat = new ADOX.CatalogClass();
   cat.Create("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + dbName + ";");
   Response.Write("数据库:" + dbName + "已经创建成功!");
   ADOX.TableClass tbl = new ADOX.TableClass();
   tbl.ParentCatalog = cat;
   tbl.Name = "MyTable";
  
   //增加一个自动增长的字段
   ADOX.ColumnClass col = new ADOX.ColumnClass();
   col.ParentCatalog = cat;
   col.Type = ADOX.DataTypeEnum.adInteger; // 必须先设置字段类型
   col.Name = "id";
   col.Properties["Jet OLEDB:Allow Zero Length"].Value = false;
   col.Properties["AutoIncrement"].Value = true;
   tbl.Columns.Append(col, ADOX.DataTypeEnum.adInteger, 0);
  
   //增加一个文本字段
   ADOX.ColumnClass col2 = new ADOX.ColumnClass();
   col2.ParentCatalog = cat;
   col2.Name = "Description";
   col2.Properties["Jet OLEDB:Allow Zero Length"].Value = false;
   tbl.Columns.Append(col2, ADOX.DataTypeEnum.adVarChar, 25);
  
   //增加数字字段
   ADOX.ColumnClass col3 = new ADOX.ColumnClass();
   col3.ParentCatalog = cat;
   col3.Name = "数字";
   col3.Type = DataTypeEnum.adDouble;
   col3.Properties["Jet OLEDB:Allow Zero Length"].Value = false;
   tbl.Columns.Append(col3, ADOX.DataTypeEnum.adDouble, 666);
  
   //增加Ole字段
   ADOX.ColumnClass col4 = new ADOX.ColumnClass();
   col4.ParentCatalog = cat;
   col4.Name = "Ole类型";
   col4.Type = DataTypeEnum.adLongVarBinary;
   col4.Properties["Jet OLEDB:Allow Zero Length"].Value = false;
   tbl.Columns.Append(col4, ADOX.DataTypeEnum.adLongVarBinary, 0);
  
  
   //设置主键
   tbl.Keys.Append("PrimaryKey", ADOX.KeyTypeEnum.adKeyPrimary, "id", "", "");
   cat.Tables.Append(tbl);
  
   msg.Text = ("<br>数据库表:" + tbl.Name + "已经创建成功!");
  
   System.Runtime.InteropServices.Marshal.ReleaseComObject(tbl);
   System.Runtime.InteropServices.Marshal.ReleaseComObject(cat);
   tbl = null;
   cat = null;
   GC.WaitForPendingFinalizers();
   GC.Collect();
   }
  </script>
  
  <html xmlns="http://www.w3.org/1999/xhtml">
  <head runat="server">
   <title>在.NET框架下动态创建Access数据库和表</title>
  </head>
  <body>
   <form id="form1" runat="server">
   <asp:Label ID="msg" runat="server" />
   </form>
  </body>
  </html>
  
    。



来源:upschool.com.cn
作者:
关键字:.NET
发表日期:2006-12-18

网页显示有限 阅读全文请下载本文完整版WORD文档

上一篇:利用GridView显示主细表并添加删除、打开、关闭功能(续)   下一篇:DataSet 添加数据集、行、列、主键和外键等操作示例


本文的相类似文章
  • .NET框架下Oracle到SQL Server迁移
  • 黑客揭密ASP.net服务器的入侵
  • ASP.Net漏洞 黑客可绕过安全设置
  • ASP.NET中如何防范SQL注入式攻击
  • ASP.NET中树形图的实现 3
  • ASP.NET 2.0中随机读取Access数据库记录
  • ASP.NET中树形图的实现 1
  • ASP.NET中树形图的实现 2
  • .NET里的MTS
  • 使用Reflection获取.NET组件的信息
  • 网友评论 查看本文全部评论
    笔 名: *
    评 论:
    最多500字。当前字数:0
    联系方式:
    验证码:
    在学习中进步 在进步中成长 教程中国相随您的成长之路
    华腾联合科技股份有限公司版权所有
    广告联系:Rosibo@163.com