Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 表  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701991
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何清空、初始化一个数据库?

作者:cg1  摘自:access911.net  :cg1  更新日期:2006-7-24  浏览人次:

 

如何清空、初始化一个数据库?


思路:
方法一:通过ADO 或者系统表找到所有的表名,然后通过组织 JET SQL 的 DELETE FROM [TABLENAME] 语句来删除所有表中的数据;
清空数据以后用 ADO 获取系统的自动编号字段,判断其是否为自动增加、长整字段,然后再组织 JET SQL 的 DDL 语句来初始化自动编号;
所有数据初始化结束后还要压缩修复数据库。

方法二:如果可能,在创建上述数据库后就应该立即复制一份全新的备份,这样就不用事后编程来进行初始化了。

方法三:如果是纯 ACCESS 环境可以用 TransferDatabase 的一个参数 StructureOnly 来导入结构本身。但是上述方法 VB+MDB ASP+MDB .NET+MDB 环境不适用


上述思路涉及到的知识点本站文章都已经论述过了。

    只用ado列出所有的表《ADO/DAO/ADO.NET》
    http://access911.net/index.asp?u1=a&u2=72FAB71E14DC

    ado如何取得表的所有字段信息?《VBA》
    http://access911.net/index.asp?u1=a&u2=74FAB11E10DC

    《查询》如何定义自动编号字段的初始值和步进值?
    http://access911.net/index.asp?u1=a&u2=71FAB01E13DC

    如何使用 ADO 來压缩或修复 MS Access 文件?(jro的使用)《其他》
    http://access911.net/index.asp?u1=a&u2=71FAB71E


这里列出网友“wangtiecheng(/+〆=ろ)”提供的部分代码:
'在模块中创建公共函数,执行即可。
'用ADO
Public Sub DeleteAllData()
    Dim strSQL As String
    Dim Cnn As New ADODB.Connection
    Dim Rst As New ADODB.Recordset
    
    Set Cnn = CurrentProject.Connection
    
    strSQL = "SELECT Name FROM MSysObjects WHERE Flags=0 AND Type=1"
    Rst.Open strSQL, Cnn, adOpenKeyset, adLockOptimistic
    If Not Rst.EOF Then
        Rst.MoveFirst
        Do While Not Rst.EOF
            strSQL = "delete * from " & Rst!Name
            Cnn.Execute strSQL
            
            Rst.MoveNext
        Loop
    End If
    
    MsgBox "OK"
End Sub


本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利