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

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Access/Query&amp;diff=1368&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/Query&amp;diff=1368&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/Query&amp;diff=1369&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/Query&amp;diff=1369&amp;oldid=prev"/>
				<updated>2010-05-26T12:46:57Z</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;==Create Query by using the Database.CreateQueryDef==&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 exaPropertyandMethod()&lt;br /&gt;
    Dim dbLib As Database&lt;br /&gt;
    Dim qdfExpensive As QueryDef&lt;br /&gt;
    Set dbLib = CurrentDb()&lt;br /&gt;
    Debug.Print dbLib.Name&lt;br /&gt;
    Set qdfExpensive = dbLib.CreateQueryDef(&amp;quot;Expensive&amp;quot;, &amp;quot;SELECT * FROM BOOKS WHERE Price &amp;gt; 20&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;
==Creating a Pass-Through Query with ADOX==&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 Create_PassThroughQuery()&lt;br /&gt;
   Dim cat As ADOX.Catalog&lt;br /&gt;
   Dim cmd As ADODB.rumand&lt;br /&gt;
   Dim myRecordset As ADODB.Recordset&lt;br /&gt;
   Dim strPath As String&lt;br /&gt;
   Dim strSQL As String&lt;br /&gt;
   Dim strQryName As String&lt;br /&gt;
   Dim strODBCConnect As String&lt;br /&gt;
   On Error GoTo ErrorHandler&lt;br /&gt;
   strSQL = &amp;quot;SELECT Customers.* FROM Customers WHERE Customers.Country=&amp;quot;France&amp;quot;;&amp;quot;&lt;br /&gt;
   strQryName = &amp;quot;French Customers&amp;quot;&lt;br /&gt;
   &lt;br /&gt;
   strODBCConnect = &amp;quot;ODBC;Driver=SQL Server;Server=yourserver\yourName;&amp;quot; &amp;amp; _&lt;br /&gt;
      &amp;quot;Database=Northwind;UID=;PWD=&amp;quot;&lt;br /&gt;
   Set cat = New ADOX.Catalog&lt;br /&gt;
   cat.ActiveConnection = CurrentProject.Connection&lt;br /&gt;
   Set cmd = New ADODB.rumand&lt;br /&gt;
   With cmd&lt;br /&gt;
      .ActiveConnection = cat.ActiveConnection&lt;br /&gt;
      .rumandText = strSQL&lt;br /&gt;
      .Properties(&amp;quot;Jet OLEDB:ODBC Pass-Through Statement&amp;quot;) = True&lt;br /&gt;
      .Properties(&amp;quot;Jet OLEDB:Pass-Through Query Connect String&amp;quot;) = _&lt;br /&gt;
          strODBCConnect&lt;br /&gt;
   End With&lt;br /&gt;
   cat.Procedures.Append strQryName, cmd&lt;br /&gt;
   Set cmd = Nothing&lt;br /&gt;
   Set cat = Nothing&lt;br /&gt;
   Exit Sub&lt;br /&gt;
ErrorHandler:&lt;br /&gt;
   If InStr(Err.Description, &amp;quot;already exists&amp;quot;) Then&lt;br /&gt;
      cat.Procedures.Delete strQryName&lt;br /&gt;
      Resume&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;
==Creating a Query Using Code==&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 CreateQuery()&lt;br /&gt;
    Dim cmd As ADODB.rumand&lt;br /&gt;
    Dim strSQL As String&lt;br /&gt;
    Dim cat As ADOX.Catalog&lt;br /&gt;
    Set cat = New ADOX.Catalog&lt;br /&gt;
    cat.ActiveConnection = CurrentProject.Connection&lt;br /&gt;
    Set cmd = New ADODB.rumand&lt;br /&gt;
    cmd.rumandText = &amp;quot;Select * From Employees Where State=&amp;quot;CA&amp;quot;&amp;quot;&lt;br /&gt;
    cat.Views.Append &amp;quot;qryCAClients&amp;quot;, cmd&lt;br /&gt;
    cat.Views.Refresh&lt;br /&gt;
    Set cat = Nothing&lt;br /&gt;
    Set cmd = 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;
==Delete a query==&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;
Private Sub TimeToCompletionI()&lt;br /&gt;
    Dim db As Database&lt;br /&gt;
    Set db = CurrentDb&lt;br /&gt;
    &lt;br /&gt;
    Dim qry1 As QueryDef&lt;br /&gt;
    Dim sSQL1 As String&lt;br /&gt;
    &lt;br /&gt;
    On Error Resume Next&lt;br /&gt;
    db.QueryDefs.Delete &amp;quot;temp1&amp;quot;&lt;br /&gt;
    On Error GoTo 0&lt;br /&gt;
    &lt;br /&gt;
    sSQL1 = &amp;quot;SELECT * from Employees&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
    Set qry1 = db.CreateQueryDef(&amp;quot;temp1&amp;quot;, sSQL1)&lt;br /&gt;
    &lt;br /&gt;
    DoCmd.OpenQuery qry1.Name&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;
==Execuate query==&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 UsingQuery()&lt;br /&gt;
  Dim conn As ADODB.Connection&lt;br /&gt;
  Dim recs As Long&lt;br /&gt;
  Set conn = CurrentProject.Connection&lt;br /&gt;
  With conn&lt;br /&gt;
    .Execute &amp;quot;qryUpdateCountry&amp;quot;, recs, adExecuteNoRecords&lt;br /&gt;
    .Close&lt;br /&gt;
  End With&lt;br /&gt;
  Set conn = Nothing&lt;br /&gt;
  MsgBox recs &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;
==Executing a Pass-Through Query Saved in Access==&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 Execute_PassThroughQuery()&lt;br /&gt;
   Dim cat As ADOX.Catalog&lt;br /&gt;
   Dim cmd As ADODB.rumand&lt;br /&gt;
   Dim myRecordset As ADODB.Recordset&lt;br /&gt;
   Dim strConnect As String&lt;br /&gt;
   strConnect = &amp;quot;Provider=SQLOLEDB;Data Source=yourServer\yourName;&amp;quot; &amp;amp; _&lt;br /&gt;
      &amp;quot;Initial Catalog=Northwind;User Id=sa;Password=&amp;quot;&lt;br /&gt;
   Set cat = New ADOX.Catalog&lt;br /&gt;
   cat.ActiveConnection = CurrentProject.Connection&lt;br /&gt;
   Set cmd = New ADODB.rumand&lt;br /&gt;
   Set cmd = cat.Procedures(&amp;quot;French Customers&amp;quot;).rumand&lt;br /&gt;
   Set myRecordset = cmd.Execute&lt;br /&gt;
   Debug.Print myRecordset.GetString&lt;br /&gt;
   Set myRecordset = Nothing&lt;br /&gt;
   Set cmd = Nothing&lt;br /&gt;
   Set cat = 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;
==Get the created query name==&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;
Private Sub OverlappingIntervals()&lt;br /&gt;
    Dim db As Database&lt;br /&gt;
    Set db = CurrentDb&lt;br /&gt;
    &lt;br /&gt;
    Dim qry As QueryDef&lt;br /&gt;
    Dim sSQL As String&lt;br /&gt;
    &lt;br /&gt;
    On Error Resume Next&lt;br /&gt;
    db.QueryDefs.Delete &amp;quot;temp&amp;quot;&lt;br /&gt;
    On Error GoTo 0&lt;br /&gt;
    &lt;br /&gt;
    sSQL = &amp;quot;SELECT * from Employees&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
    Set qry = db.CreateQueryDef(&amp;quot;temp&amp;quot;, sSQL)&lt;br /&gt;
    &lt;br /&gt;
    DoCmd.OpenQuery qry.Name&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;
==Making Bulk Changes==&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 RunUpdateQuery()&lt;br /&gt;
    Dim cnn As ADODB.Connection&lt;br /&gt;
    Set cnn = New ADODB.Connection&lt;br /&gt;
    Set cnn = CurrentProject.Connection&lt;br /&gt;
    cnn.Execute &amp;quot;qryIncreaseTotalEstimate&amp;quot;&lt;br /&gt;
    cnn.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;
==Pass parameter to a query==&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 DeleteCust(lngID As Long)&lt;br /&gt;
  Dim cmd As ADODB.rumand&lt;br /&gt;
  Set cmd = New ADODB.rumand&lt;br /&gt;
  With cmd&lt;br /&gt;
  .ActiveConnection = CurrentProject.Connection&lt;br /&gt;
  .rumandText = &amp;quot;qryDeleteCompany&amp;quot;&lt;br /&gt;
  .rumandType = adCmdStoredProc&lt;br /&gt;
  .Execute , Parameters:=lngID&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;
==Update a table with QueryDef==&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 exaCreateAction()&lt;br /&gt;
    Dim db As Database&lt;br /&gt;
    Dim qdf As QueryDef&lt;br /&gt;
    Dim strSQL As String&lt;br /&gt;
    &lt;br /&gt;
    Set db = CurrentDb&lt;br /&gt;
    &lt;br /&gt;
    strSQL = &amp;quot;UPDATE BOOKS SET Price = Price*1.1 WHERE Price &amp;gt; 20&amp;quot;&lt;br /&gt;
    &lt;br /&gt;
    Set qdf = db.CreateQueryDef(&amp;quot;PriceInc&amp;quot;, strSQL)&lt;br /&gt;
    &lt;br /&gt;
    qdf.Execute&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;
==User Defined 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;
Sub exaUserDefinedProperty()&lt;br /&gt;
    Dim db As Database&lt;br /&gt;
    Dim tbl As TableDef&lt;br /&gt;
    Dim prp As Property&lt;br /&gt;
    &lt;br /&gt;
    Dim str As String&lt;br /&gt;
    &lt;br /&gt;
    Set db = CurrentDb&lt;br /&gt;
    Set tbl = db!BOOKS&lt;br /&gt;
    &lt;br /&gt;
    Set prp = tbl.CreateProperty(&amp;quot;UserProperty&amp;quot;, dbText, &amp;quot;Programming DAO is fun.&amp;quot;)&lt;br /&gt;
    tbl.Properties.Append prp&lt;br /&gt;
    str = &amp;quot;&amp;quot;&lt;br /&gt;
    For Each prp In tbl.Properties&lt;br /&gt;
        Debug.Print prp.Name&lt;br /&gt;
        Debug.Print prp.Value&lt;br /&gt;
        Debug.Print prp.Type&lt;br /&gt;
        Debug.Print prp.Inherited&lt;br /&gt;
    Next prp&lt;br /&gt;
    Debug.Print tbl.Properties.Count &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;
==Using a Stored Procedure to Make Bulk Changes to Data in a SQL Server 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 RunUpdateQuery()&lt;br /&gt;
    Dim cnn As ADODB.Connection&lt;br /&gt;
    Set cnn = New ADODB.Connection&lt;br /&gt;
    &amp;quot;Establish the connection and execute a stored procedure&lt;br /&gt;
    cnn.Open &amp;quot;Provider=SQLOLEDB.1;&amp;quot; &amp;amp; _&lt;br /&gt;
            &amp;quot;Data Source=(local); Initial Catalog=NorthWind;&amp;quot; &amp;amp; _&lt;br /&gt;
            &amp;quot;Integrated Security=SSPI&amp;quot;&lt;br /&gt;
    cnn.Execute &amp;quot;procIncreaseTotalEstimate&amp;quot;&lt;br /&gt;
    cnn.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;
==Using CreateParameter to delete a company record==&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 DeleteCustParam()&lt;br /&gt;
  Dim cmd As ADODB.rumand&lt;br /&gt;
  Dim prm As ADODB.Parameter&lt;br /&gt;
  Set cmd = New ADODB.rumand&lt;br /&gt;
  With cmd&lt;br /&gt;
    .ActiveConnection = CurrentProject.Connection&lt;br /&gt;
    .rumandText = &amp;quot;qryDeleteCompany&amp;quot;&lt;br /&gt;
    .rumandType = adCmdStoredProc&lt;br /&gt;
    Set prm = cmd.CreateParameter(Name:=&amp;quot;MyParam&amp;quot;, Type:=adInteger,Direction:=adParamInput).Parameters.Append prm&lt;br /&gt;
    prm.Value = 13&lt;br /&gt;
    .Execute&lt;br /&gt;
  End With&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>