<?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%2FExcel%2FExcel_ADO</id>
		<title>VBA/Excel/Access/Word/Excel/Excel ADO - История изменений</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%2FExcel%2FExcel_ADO"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Excel_ADO&amp;action=history"/>
		<updated>2026-04-07T05:39:18Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Excel_ADO&amp;diff=1672&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/Excel/Excel_ADO&amp;diff=1672&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/Excel/Excel_ADO&amp;diff=1673&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/Excel/Excel_ADO&amp;diff=1673&amp;oldid=prev"/>
				<updated>2010-05-26T12:47:49Z</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;==Excel based 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 ExcelExample()&lt;br /&gt;
    Dim r As Integer, f As Integer&lt;br /&gt;
    Dim vrecs As Variant&lt;br /&gt;
    Dim rs As ADODB.Recordset&lt;br /&gt;
    Dim cn As ADODB.Connection&lt;br /&gt;
    Dim fld As ADODB.Field&lt;br /&gt;
    Set cn = New ADODB.Connection&lt;br /&gt;
    cn.Provider = &amp;quot;Microsoft OLE DB Provider for ODBC Drivers&amp;quot;&lt;br /&gt;
    cn.ConnectionString = &amp;quot;DRIVER={Microsoft Excel Driver (*.xls)};DBQ=C:\mydb.mdb;&amp;quot;&lt;br /&gt;
    cn.Open&lt;br /&gt;
    Debug.Print cn.ConnectionString&lt;br /&gt;
    Set rs = New ADODB.Recordset&lt;br /&gt;
    rs.CursorLocation = adUseClient&lt;br /&gt;
    rs.Open &amp;quot;SELECT * FROM Employees&amp;quot;, cn, adOpenDynamic, adLockOptimistic&lt;br /&gt;
    For Each fld In rs.Fields&lt;br /&gt;
        Debug.Print fld.Name,&lt;br /&gt;
    Next&lt;br /&gt;
    Debug.Print&lt;br /&gt;
    vrecs = rs.GetRows(6)&lt;br /&gt;
    For r = 0 To UBound(vrecs, 1)&lt;br /&gt;
        For f = 0 To UBound(vrecs, 2)&lt;br /&gt;
            Debug.Print vrecs(f, r),&lt;br /&gt;
        Next&lt;br /&gt;
        Debug.Print&lt;br /&gt;
    Next&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;
    cn.Close&lt;br /&gt;
    &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;
==Insert a row to a worksheet by using the SQL statement==&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;
Public Sub WorksheetInsert()&lt;br /&gt;
  Dim Connection As ADODB.Connection&lt;br /&gt;
  Dim ConnectionString As String&lt;br /&gt;
  ConnectionString = &amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;Data Source=&amp;quot; &amp;amp; ThisWorkbook.Path &amp;amp; &amp;quot;\Sales.xls;&amp;quot; &amp;amp; _&lt;br /&gt;
    &amp;quot;Extended Properties=Excel 8.0;&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
  Dim SQL As String&lt;br /&gt;
    &lt;br /&gt;
  SQL = &amp;quot;INSERT INTO [Sales$] VALUES(&amp;quot;VA&amp;quot;, &amp;quot;On&amp;quot;, &amp;quot;Computers&amp;quot;, &amp;quot;Mid&amp;quot;, 30)&amp;quot;&lt;br /&gt;
  Set Connection = New ADODB.Connection&lt;br /&gt;
  Call Connection.Open(ConnectionString)&lt;br /&gt;
    &lt;br /&gt;
  Call Connection.Execute(SQL, , CommandTypeEnum.adCmdText Or ExecuteOptionEnum.adExecuteNoRecords)&lt;br /&gt;
  Connection.Close&lt;br /&gt;
  Set Connection = 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;
==Opening an Excel Spreadsheet with ADO==&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 Open_ExcelSpread()&lt;br /&gt;
   Dim conn As ADODB.Connection&lt;br /&gt;
   Set conn = New ADODB.Connection&lt;br /&gt;
   conn.Open &amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;&amp;quot; &amp;amp; _&lt;br /&gt;
       &amp;quot;Data Source=&amp;quot; &amp;amp; CurrentProject.Path &amp;amp; _&lt;br /&gt;
       &amp;quot;\Report.xls;&amp;quot; &amp;amp; _&lt;br /&gt;
       &amp;quot;Extended Properties=Excel 8.0;&amp;quot;&lt;br /&gt;
   conn.Close&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;
==Use ADO to read the data from Access database to Excel==&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;
Public Sub SavedQuery()&lt;br /&gt;
    &lt;br /&gt;
  Dim Field As ADODB.Field&lt;br /&gt;
  Dim Recordset As ADODB.Recordset&lt;br /&gt;
  Dim Offset As Long&lt;br /&gt;
    &lt;br /&gt;
  Const ConnectionString As String = &amp;quot;Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\mydb.mdb;Persist Security Info=False&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
  Set Recordset = New ADODB.Recordset&lt;br /&gt;
  Call Recordset.Open(&amp;quot;[Sales By Category]&amp;quot;, ConnectionString, _&lt;br /&gt;
    CursorTypeEnum.adOpenForwardOnly, LockTypeEnum.adLockReadOnly, _&lt;br /&gt;
    CommandTypeEnum.adCmdTable)&lt;br /&gt;
  If Not Recordset.EOF Then&lt;br /&gt;
    With Sheet1.Range(&amp;quot;A1&amp;quot;)&lt;br /&gt;
      For Each Field In Recordset.Fields&lt;br /&gt;
        .Offset(0, Offset).Value = Field.Name&lt;br /&gt;
        Offset = Offset + 1&lt;br /&gt;
      Next Field&lt;br /&gt;
      .Resize(1, Recordset.Fields.Count).Font.Bold = True&lt;br /&gt;
    End With&lt;br /&gt;
    Call Sheet1.Range(&amp;quot;A2&amp;quot;).CopyFromRecordset(Recordset)&lt;br /&gt;
    Sheet1.UsedRange.EntireColumn.AutoFit&lt;br /&gt;
  Else&lt;br /&gt;
    Debug.Print &amp;quot;Error: No records returned.&amp;quot;&lt;br /&gt;
  End If&lt;br /&gt;
  Recordset.Close&lt;br /&gt;
  Set Recordset = Nothing&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>