VB.Net透过JRO修复Access MDB

  次阅读 作者:智能小宝 来源:互联网 2016-01-19 12:49 我要评论(0)

Imports System

Imports System.IO

Public Class Form1

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

' 将C:db1.mdb 做Compact / Repair

If Compact_MDB("C:db1.mdb") Then MessageBox.Show("OK !")

End Sub

Private Function Compact_MDB(ByVal strFile As String) As Boolean

' Jet Access (MDB) 连线字串; Jet ( Joint Engine Technology )

Dim strCn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0}"

' 或"Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Jet OLEDB:Engine Type=5"

' Path.GetTempFileName 方法: 在磁碟上建立具命之零位元组的唯一暂存档案,

' 然後传回该档案的完整路径。

Dim strTmpFile As String = Path.GetTempFileName.Replace(".tmp", ".mdb") ' 把tmp 副档名改成mdb

' 建立物件阵列存放引数(参数) , 来源, 目的

Dim objPara As Object() = New Object() {String.Format(strCn, strFile), String.Format(strCn, strTmpFile)}

' Activator 成员: 包含本机或远端建立物件型别的方法,或者取得对现有远端物件的参考。

' Activator.CreateInstance 方法(Type) : 使用最符合指定参数的建构函式,建立指定型别的执行个体。

Dim objJRO As Object = Activator.CreateInstance(Type.GetTypeFromProgID("JRO.JetEngine"))

' Type.GetTypeFromProgID 方法: 取得与指定的程式识别项(ProgID) 关联的型别;

' 如果在载入Type 时发生错误,则传回null。

' JRO.JetEngine 为Microsoft Jet and Replication Objects X.X library

' Type.InvokeMember 方法

' Type.InvokeMember (String, BindingFlags, Binder, Object, Object[])

objJRO.GetType.InvokeMember("CompactDatabase", Reflection.BindingFlags.InvokeMethod, _

Nothing, objJRO, objPara)

' 使用指定的系结条件约束并符合指定的引数清单,来叫用指定的成员。

' BindingFlags 列举型别,InvokeMethod 指定要叫用方法。

File.Delete(strFile) ' File.Delete 方法: 删除Compact 前之mdb 档

File.Move(strTmpFile, strFile) ' File.Move 方法: 将Compact 过的mdb 档改成(回)正确档名

' Marshal.ReleaseComObject 方法释放JRO COM 物件

Runtime.InteropServices.Marshal.ReleaseComObject(objJRO)

objJRO = Nothing

Return True

End Function

End Class

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...