马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
VB建立ACCESS数据库:
需要引用DAO3.6
Dim Wrk As Workspace
Dim dbs As Database
Dim tdfNew As TableDef
Dim DayTime As String
DayTime = CStr(Format(Now, "yyyy_mm_dd"))
Set Wrk = DBEngine.Workspaces(0)
Set dbs = CreateDatabase(App.Path & "\" & DayTime, dbLangGeneral) '建立数据库
Set dbs = OpenDatabase(App.Path & "\" & DayTime, False, False)'打开数据库
Set dbs = DBEngine.Workspaces(0).OpenDatabase(App.Path & "\" & DayTime, False, False)
Set tdfNew = dbs.CreateTableDef("当班测量数据表") ' 建立数据表
tdfNew.Fields.Append tdfNew.CreateField("编号", dbInteger, 10) '定义表中的字段
tdfNew.Fields.Append tdfNew.CreateField("注油前重量", dbDouble, 20)
tdfNew.Fields.Append tdfNew.CreateField("注油后重量", dbDouble, 20)
tdfNew.Fields.Append tdfNew.CreateField("注油量", dbDouble, 20)
dbs.TableDefs.Append tdfNew
dbs.Close
以上方法建立的ACCESS数据库没有设置主键,也没有定义自动+1的编号列 在有些情况下不适合使用
在查找了很多有关VB ADODC的控件资料、代码之后也没有找到合适的方法能实现建库是增加一列自动+1编号列和设置主键
于是搜索了MSDN上关于CREATE TABLE的相关资料后 采用以下语句实现:
Dim Wrk As Workspace
Dim dbs As Database
Dim DayTime As String
DayTime = CStr(Format(Now, "yyyy_mm_dd"))
Set Wrk = DBEngine.Workspaces(0)
Set dbs = CreateDatabase(App.Path & "\" & DayTime, dbLangGeneral) 'C:\历史以往数据保存
Set dbs = OpenDatabase(App.Path & "\" & DayTime, False, False)
dbs.Execute "CREATE TABLE 当班测量数据表(编号 autoincrement(1,1) primary key, 注油前重量 Double,注油后重量 Double,注油量 Double,CONSTRAINT MyTableConstraint UNIQUE(编号, 注油前重量, 注油后重量,注油量));"
dbs.Close
|