<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VBA%2FExcel%2FAccess%2FWord%2FAccess%2FMicrosoft_Jet</id>
		<title>VBA/Excel/Access/Word/Access/Microsoft Jet - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VBA%2FExcel%2FAccess%2FWord%2FAccess%2FMicrosoft_Jet"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Microsoft_Jet&amp;action=history"/>
		<updated>2026-04-06T13:01:26Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Microsoft_Jet&amp;diff=1268&amp;oldid=prev</id>
		<title> в 16:33, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Microsoft_Jet&amp;diff=1268&amp;oldid=prev"/>
				<updated>2010-05-26T16:33:00Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 16:33, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Microsoft_Jet&amp;diff=1269&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Microsoft_Jet&amp;diff=1269&amp;oldid=prev"/>
				<updated>2010-05-26T12:46:43Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==A Simple Connection Example==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub MakeConnectionExample() &lt;br /&gt;
    Dim conn As ADODB.Connection &lt;br /&gt;
    On Error GoTo ErrHandler &lt;br /&gt;
    Set conn = New ADODB.Connection &lt;br /&gt;
    conn.Provider = &amp;quot;Microsoft.Jet.OLEDB.4.0;&amp;quot; &lt;br /&gt;
    conn.ConnectionString = &amp;quot;Data Source=&amp;quot; &amp;amp; CurrentProject.Path &amp;amp;&amp;quot;\mydb.mdb&amp;quot; &lt;br /&gt;
    conn.Open &lt;br /&gt;
    If conn.State = adStateOpen Then &lt;br /&gt;
        MsgBox &amp;quot;Connected!&amp;quot;, vbOKOnly &lt;br /&gt;
        conn.Close &lt;br /&gt;
    Else &lt;br /&gt;
        MsgBox &amp;quot;Not connected!&amp;quot;, vbOKCancel &lt;br /&gt;
    End If &lt;br /&gt;
    Set conn = Nothing &lt;br /&gt;
    Exit Sub &lt;br /&gt;
ErrHandler: &lt;br /&gt;
    MsgBox &amp;quot;Could not connect to database. &amp;quot; &amp;amp; Err.Description, _ &lt;br /&gt;
        vbOKOnly &lt;br /&gt;
End Sub &lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Connection String to Access database==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub AccessExample()&lt;br /&gt;
    Dim rs As ADODB.Recordset&lt;br /&gt;
    Dim cn As ADODB.Connection&lt;br /&gt;
    &lt;br /&gt;
    Set cn = New ADODB.Connection&lt;br /&gt;
    cn.Provider = &amp;quot;Microsoft.Jet.OLEDB.4.0;&amp;quot;&lt;br /&gt;
    cn.ConnectionString = &amp;quot;Data Source=C:\mydb.mdb&amp;quot;&lt;br /&gt;
    cn.Open&lt;br /&gt;
    &lt;br /&gt;
    Debug.Print &amp;quot;Full connection string: &amp;quot; &amp;amp; cn.ConnectionString&lt;br /&gt;
    &lt;br /&gt;
    Set rs = cn.OpenSchema(adSchemaTables)&lt;br /&gt;
    Do While Not rs.EOF&lt;br /&gt;
        Debug.Print rs!TABLE_NAME &amp;amp; &amp;quot;  Type: &amp;quot; &amp;amp; rs!TABLE_TYPE&lt;br /&gt;
        rs.MoveNext&lt;br /&gt;
    Loop&lt;br /&gt;
    rs.Close&lt;br /&gt;
    cn.Close&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==connect to JET==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub Jet()&lt;br /&gt;
    Dim conn As ADODB.Connection&lt;br /&gt;
    Dim rst As ADODB.Recordset&lt;br /&gt;
    Set conn = New ADODB.Connection&lt;br /&gt;
    With conn&lt;br /&gt;
        .Provider = &amp;quot;Microsoft.Jet.OLEDB.3.51&amp;quot;&lt;br /&gt;
        .ConnectionString = &amp;quot;data source=&amp;quot; &amp;amp; _&lt;br /&gt;
            App.Path &amp;amp; &amp;quot;\sample.mdb&amp;quot;&lt;br /&gt;
        .Mode = adModeRead&lt;br /&gt;
        .Open&lt;br /&gt;
    End With&lt;br /&gt;
    MsgBox &amp;quot;Connected to &amp;quot; &amp;amp; conn.Provider, vbInformation&lt;br /&gt;
    Set rst = New ADODB.Recordset&lt;br /&gt;
    rst.Open &amp;quot;Customers&amp;quot;, conn&lt;br /&gt;
    MsgBox rst!CompanyName, vbInformation&lt;br /&gt;
    rst.Close&lt;br /&gt;
    Set rst = Nothing&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Create new database==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub CreateDatabase()&lt;br /&gt;
    Dim cat As New ADOX.Catalog&lt;br /&gt;
    cat.Create &amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;&amp;quot; &amp;amp; _&lt;br /&gt;
       &amp;quot;Data Source=C:\mydb.mdb;&amp;quot;&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Include the database version information with the JetOLEDB:Engine Type property==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;quot; you must make sure that a reference to&lt;br /&gt;
&amp;quot; Microsoft ADO Ext. 2.5 for DDL and Security&lt;br /&gt;
&amp;quot; Object Library is set in the References dialog box&lt;br /&gt;
Sub CreateI_NewDatabase()&lt;br /&gt;
   Dim cat As ADOX.Catalog&lt;br /&gt;
   Dim strDb As String&lt;br /&gt;
   Set cat = New ADOX.Catalog&lt;br /&gt;
   strDb = &amp;quot;C:\NewAccessDb.mdb&amp;quot;&lt;br /&gt;
   On Error GoTo ErrorHandler&lt;br /&gt;
cat.Create &amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;&amp;quot; &amp;amp; _&lt;br /&gt;
    &amp;quot;Data Source=&amp;quot; &amp;amp; strDb &amp;amp; _&lt;br /&gt;
    &amp;quot;Jet OLEDB:Encrypt Database=True;&amp;quot; &amp;amp; _&lt;br /&gt;
    &amp;quot;Jet OLEDB:Engine Type=1;&amp;quot;&lt;br /&gt;
   MsgBox &amp;quot;The database was created (&amp;quot; &amp;amp; strDb &amp;amp; &amp;quot;).&amp;quot;&lt;br /&gt;
   Set cat = Nothing&lt;br /&gt;
   Exit Sub&lt;br /&gt;
ErrorHandler:&lt;br /&gt;
   If Err.Number = -2147217897 Then&lt;br /&gt;
      Kill strDb&lt;br /&gt;
      Resume 0&lt;br /&gt;
   Else&lt;br /&gt;
      MsgBox Err.Number &amp;amp; &amp;quot;: &amp;quot; &amp;amp; Err.Description&lt;br /&gt;
   End If&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Open a worksheet through OLEDB==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub openWorksheet()&lt;br /&gt;
   Dim myConnection As New ADODB.Connection&lt;br /&gt;
   Dim myRecordset As ADODB.Recordset&lt;br /&gt;
   &lt;br /&gt;
   myConnection.Open &amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;&amp;quot; &amp;amp; _&lt;br /&gt;
             &amp;quot;Data Source=C:\Customers.xls;&amp;quot; &amp;amp; _&lt;br /&gt;
             &amp;quot;Extended Properties=Excel 8.0;&amp;quot;&lt;br /&gt;
   &lt;br /&gt;
   Set myRecordset = New ADODB.Recordset&lt;br /&gt;
   myRecordset.Open &amp;quot;customers&amp;quot;, myConnection, , , adCmdTable&lt;br /&gt;
   &lt;br /&gt;
   Do Until myRecordset.EOF&lt;br /&gt;
      Debug.Print myRecordset(&amp;quot;txtCustNumber&amp;quot;), myRecordset(&amp;quot;txtBookPurchased&amp;quot;)&lt;br /&gt;
      myRecordset.MoveNext&lt;br /&gt;
   Loop&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Opening a Microsoft Jet Database in Read/Write Mode==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&amp;quot;Intrinsic constants of the Connection object&amp;quot;s Mode property &lt;br /&gt;
Constant Name           Value    Type of Permission&lt;br /&gt;
adModeUnknown           0        Permissions have not been set yet or cannot be determined. This is the default setting.&lt;br /&gt;
adModeRead              1        Read-only permissions&lt;br /&gt;
adModeWrite             2        Write-only permissions&lt;br /&gt;
adModeReadWrite         3        Read/write permissions&lt;br /&gt;
adModeShareDenyRead     4        Prevents others from opening the connection with read permissions&lt;br /&gt;
adModeShareDenyWrite    8        Prevents others from opening the connection with write permissions&lt;br /&gt;
adModeShareExclusive    12       Prevents others from opening the connection&lt;br /&gt;
adModeShareDenyNone     16       Prevents others from opening the connection with any permissions&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Read table schema==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub ReadSchema()&lt;br /&gt;
    Dim conn As ADODB.Connection&lt;br /&gt;
    Dim rst As ADODB.Recordset&lt;br /&gt;
    Set conn = New ADODB.Connection&lt;br /&gt;
    With conn&lt;br /&gt;
        .Provider = &amp;quot;Microsoft.Jet.OLEDB.4.0&amp;quot;&lt;br /&gt;
        .ConnectionString = &amp;quot;Data source=&amp;quot; &amp;amp; CurrentProject.Path &amp;amp; &amp;quot;\mydb.mdb&amp;quot;&lt;br /&gt;
        .Open&lt;br /&gt;
    End With&lt;br /&gt;
    Set rst = conn.OpenSchema(adSchemaTables)&lt;br /&gt;
    Do Until rst.EOF&lt;br /&gt;
        Debug.Print &amp;quot;Catalog: &amp;quot; &amp;amp; rst!Table_Catalog&lt;br /&gt;
        Debug.Print &amp;quot;Schema: &amp;quot; &amp;amp; rst!Table_Schema&lt;br /&gt;
        Debug.Print &amp;quot;Table Name: &amp;quot; &amp;amp; rst!Table_Name&lt;br /&gt;
        Debug.Print &amp;quot;Type: &amp;quot; &amp;amp; rst!Table_Type&lt;br /&gt;
        Debug.Print &amp;quot;Date Created: &amp;quot; &amp;amp; rst!Date_Created&lt;br /&gt;
        Debug.Print &amp;quot;Date Modified&amp;quot; &amp;amp; rst!Date_Modified&lt;br /&gt;
        Debug.Print&lt;br /&gt;
        rst.moveNext&lt;br /&gt;
    Loop&lt;br /&gt;
    rst.Close&lt;br /&gt;
    conn.Close&lt;br /&gt;
    &lt;br /&gt;
    Set rst = Nothing&lt;br /&gt;
    Set conn = Nothing&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Sub addJetSqlUser()==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
   Dim myConnection As ADODB.Connection&lt;br /&gt;
   Dim newUser As ADOX.User&lt;br /&gt;
   Dim strSQL As String&lt;br /&gt;
   &lt;br /&gt;
   Set myConnection = New ADODB.Connection&lt;br /&gt;
   With myConnection&lt;br /&gt;
      .Provider = &amp;quot;Microsoft.Jet.OLEDB.4.0&amp;quot;&lt;br /&gt;
      .Properties(&amp;quot;Jet OLEDB:System database&amp;quot;) = &amp;quot;C:\demo.mdw&amp;quot;&lt;br /&gt;
      .Open &amp;quot;Data Source=c:\VBA.mdb;User ID=John;Password=;&amp;quot;&lt;br /&gt;
      strSQL = &amp;quot;CREATE USER joe [mycat] NULL&amp;quot;&lt;br /&gt;
      .Execute (strSQL)&lt;br /&gt;
   End With&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use Recordset.Support to check the supported features==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub SupportsExample()&lt;br /&gt;
    Dim rs As ADODB.Recordset&lt;br /&gt;
    Dim cn As ADODB.Connection&lt;br /&gt;
    Dim lRecordsAffected As Long&lt;br /&gt;
    Set cn = New ADODB.Connection&lt;br /&gt;
    cn.Provider = &amp;quot;Microsoft.Jet.OLEDB.4.0;&amp;quot;&lt;br /&gt;
    cn.ConnectionString = &amp;quot;Data Source=C:\mydb.mdb&amp;quot;&lt;br /&gt;
    cn.Open&lt;br /&gt;
    Set rs = New ADODB.Recordset&lt;br /&gt;
    rs.CursorLocation = adUseServer&lt;br /&gt;
    rs.Open &amp;quot;SELECT * FROM Names&amp;quot;, cn, adOpenStatic, adLockOptimistic&lt;br /&gt;
    Debug.Print &amp;quot;adAddNew: &amp;quot; &amp;amp; rs.Supports(adAddNew)&lt;br /&gt;
    Debug.Print &amp;quot;adBookmark: &amp;quot; &amp;amp; rs.Supports(adBookmark)&lt;br /&gt;
    Debug.Print &amp;quot;adDelete: &amp;quot; &amp;amp; rs.Supports(adDelete)&lt;br /&gt;
    Debug.Print &amp;quot;adFind: &amp;quot; &amp;amp; rs.Supports(adFind)&lt;br /&gt;
    Debug.Print &amp;quot;adUpdate: &amp;quot; &amp;amp; rs.Supports(adUpdate)&lt;br /&gt;
    Debug.Print &amp;quot;adMovePrevious: &amp;quot; &amp;amp; rs.Supports(adMovePrevious)&lt;br /&gt;
    rs.Close&lt;br /&gt;
    rs.CursorLocation = adUseServer&lt;br /&gt;
    rs.Open &amp;quot;SELECT * FROM Names&amp;quot;, cn, adOpenDynamic, adLockOptimistic&lt;br /&gt;
    Debug.Print &amp;quot;adAddNew: &amp;quot; &amp;amp; rs.Supports(adAddNew)&lt;br /&gt;
    Debug.Print &amp;quot;adBookmark: &amp;quot; &amp;amp; rs.Supports(adBookmark)&lt;br /&gt;
    Debug.Print &amp;quot;adDelete: &amp;quot; &amp;amp; rs.Supports(adDelete)&lt;br /&gt;
    Debug.Print &amp;quot;adFind: &amp;quot; &amp;amp; rs.Supports(adFind)&lt;br /&gt;
    Debug.Print &amp;quot;adUpdate: &amp;quot; &amp;amp; rs.Supports(adUpdate)&lt;br /&gt;
    Debug.Print &amp;quot;adMovePrevious: &amp;quot; &amp;amp; rs.Supports(adMovePrevious)&lt;br /&gt;
    &lt;br /&gt;
    rs.Close&lt;br /&gt;
    &lt;br /&gt;
    cn.Close&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>