在EXCEL中使用SQL语句查询

SQL语句在数据库使用中十分重要。
在EXCEL中可以不打开工作簿,就获取数据,对多工作簿操作很用,也很快。
对大量数据处理,比循环快很多,但是比词典方法还有点距离(可惜我还没有学会词典)。
对数据库编程,任何编程语言都要,都支持SQL语言。

借助VBA, 我们也可在EXCEL中使用它,也就是将EXCEL作为数据库
(EXCEL中对SQL功能稍有限制,如:删除数据等,但不影响我对它的推崇)
在斑竹的帮助下,对SQL在EXCEL有了一点点体会,拿出来和大家分享。
斑竹的SQL帮助文件:http://club.excelhome.net/thread-65664-1-1.html
标准的EXCEL中SQL使用见附件的各个模块,ALT+F11就能看到了{:soso_e120:}
2012-04-24  最新更新  :标准语句、实例语句和解释互动, 结果直接显示,可自己修改语句。
EXCEL2003版本: <ignore_js_op>EXCEL中的SQL学习总结-for 2003-20120424.rar (30.28 KB, 下载次数: 4765)

2012-4-24 19:06 上传
点击文件名下载附件
 


EXCEL2007版本: <ignore_js_op>EXCEL中的SQL学习总结-for 2007-20120424.rar (41.11 KB, 下载次数: 7480)

2012-4-24 19:06 上传
点击文件名下载附件
 
 
 
'在Excel中使用SQL语句总结-1:

'************************************        标准SQL查找代码:       *********************************************************
Sub SQL_Excel_2003_2007()

'On Error Resume Next       '如果出现错误,忽略,然后执行下一行代码。
Application.ScreenUpdating = False '关闭屏幕刷新,成对出现,提高速度
Application.DisplayAlerts = False '关闭提示,,成对出现,避免出现提示框

'---------------------------------------   参数声明部分  ------------------- ------------------- -------------------

    Dim cnn, SQL$   '定义数据库连接和SQL语句
    Set cnn = CreateObject("adodb.connection")  '创建数据库连接
    Set rs = CreateObject("adodb.recordset")   '创建一个数据集保存数据
   
'---------------------------------------   设置数据库连接  ------------------- ------------------- -------------------

    cnn.Open "Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & ThisWorkbook.FullName
    
       '将EXCEL文件作为数据库连接,实际并不打开EXCEL,
       'Excel2003版本:cnn.Open "Provider=Microsoft.jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" & ThisWorkbook.Path & "\数据表.xls"
       'Excel2007版本:cnn.Open "Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & ThisWorkbook.Path & "\数据表.xlsx"
       '带参数的连接字符串:cnn.Open "provider=microsoft.jet.oledb.4.0;extended properties='excel 8.0;HDR=yes;IMEX=2';data source=" & ThisWorkbook.FullName
       '    HDR=Yes   代表 Excel 档中的工作表第一行是标题栏,标题只能是一行,不能使多行,或者合并的单元格。
       '    HDR=no     工作表第一行就是数据了,沒有标题栏,不使用栏位,则栏位就以f代表,第一列列名就是:f1,第二列列名:f2
       '    IMEX 汇入模式  0 只读  1 只写   2 可读写
       '              当 IMEX=0 时为“汇出模式”,这个模式开启的 Excel 档案只能用来做“写入”用途。
       '              当 IMEX=1 时为“汇入模式”,这个模式开启的 Excel 档案只能用来做“读取”用途。
       '              当 IMEX=2 时为“连結模式”,这个模式开启的 Excel 档案可同时支援“读取”与“写入”用途。
       'Data Source  存储查询数据来源的工作薄名称,数据库路径为:数据表.xls  或本表:& ThisWorkbook.FullName
       
'---------------------------------------   设置SQL语句  ------------------- ------------------- -------------------

  SQL = "select * from  [数据表_1$A1:G100] where 姓名='马拉多纳'"
  
       '在Sheet1表内查找列名为:姓名 中所有:马拉多纳 的数据。
       '[XXX$A2:G100]的中括号和$为特别数据表标示符,XXX为Sheet名,A2:G100是选取的区域。
       'SQL语句是一个字符串,双引号开头和结尾,列名两边无单引号,表示一个字符串:‘马拉多纳’,要用单引号扩上,数字就不用了。
       'Nu=36:  AA="马拉多纳":   set  Sh=Sheet1:  SQL = "select * from  [" & Sh.name & “$] where 姓名=‘” & AA & “’  and  年龄=Nu"
       
'---------------------------------------   SQL结果处理  ------------------- ------------------- -------------------

   Set rs = cnn.Execute(SQL) '将SQL语句获得的数据传递给数据集
   Sheets("结果").Cells.ClearContents       '清理保存数据的区域
   Sheets("结果").Range("a2").CopyFromRecordset rs    '将数据集粘贴到Excel中,左上角为A2,无列名。
   'Sheets("结果").Range("b2").CopyFromRecordset cnn.Execute(SQL)  '可以不声明Y,直接使用

   cnn.Close     '关闭数据库连接
   Set cnn = Nothing    '将CNN从内存中删除。
'--------------------------------------- ------------------------ ------------------- -------------------
Application.ScreenUpdating = True
Application.DisplayAlerts = True
End Sub   '这就是最简单的EXCEL中SQL的应用 ,其他的都是SQL的运用了

转载自:http://club.excelhome.net/thread-859194-1-1.html, 感谢opiona的分享。

转载于:https://www.cnblogs.com/zhouzhilong/p/6549359.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Excel VBA 可以通过 ADODB 对象库来使用 SQL 语句。 首先,需要在 VBA 编辑器打开“工具”菜单,选择“引用”并勾选“Microsoft ActiveX Data Objects x.x Library”(x.x 为版本号,通常为最新版本)。 接下来,可以使用 ADODB 对象来连接数据库、执行 SQL 查询、更新数据库等操作。下面是一个示例代码,演示如何使用 SQL 查询获取数据库的数据: ``` Sub QueryDatabase() Dim conn As ADODB.Connection Dim rs As ADODB.Recordset Dim sql As String ' 连接数据库 Set conn = New ADODB.Connection conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\Users\username\Documents\example.accdb" conn.Open ' 执行 SQL 查询 sql = "SELECT * FROM table1" Set rs = New ADODB.Recordset rs.Open sql, conn ' 输出查询结果 Do While Not rs.EOF Debug.Print rs("column1") rs.MoveNext Loop ' 关闭连接 rs.Close conn.Close End Sub ``` 在这个示例,首先创建了一个 ADODB.Connection 对象,并使用 ConnectionString 属性设置连接字符串,指定了要连接的数据库文件路径。然后,执行 SQL 查询并将结果保存到 ADODB.Recordset 对象,最后遍历结果集并输出查询结果。 这只是一个简单的示例,实际使用可能需要根据具体情况调整代码。 ### 回答2: 在Excel VBA,可以使用SQL语句数据库进行交互。为了使用SQL语句,首先需要确保计算机上已经安装了适当的数据库引擎,并且已经将其添加到VBA项目的引用使用SQL语句的第一步是创建数据库连接对象。可以使用ADODB(ActiveX 数据对象)库的`Connection`对象来实现。使用以下代码创建数据库连接对象: ```vba Dim conn As New ADODB.Connection Dim connectionString As String connectionString = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source=C:\path\to\database.accdb" conn.Open connectionString ``` 上述代码创建了一个名为`conn`的`Connection`对象,并打开了代数据库文件路径的连接字符串。可以根据不同的数据库引擎和文件路径进行相应的更改。 接下来,可以使用`Connection`对象的`Execute`方法来执行SQL语句。以下是执行SELECT语句的示例代码: ```vba Dim rs As New ADODB.Recordset Dim sql As String sql = "SELECT * FROM TableName" rs.Open sql, conn While Not rs.EOF ' 对于每一行数据执行操作 ' 可以使用rs.Fields(index)访问每一列的值 rs.MoveNext Wend rs.Close ``` 上述代码创建了一个名为`rs`的`Recordset`对象,并执行了一个SELECT语句来检索数据。通过循环遍历记录集对象,可以逐行处理返回的数据。 除了SELECT语句外,还可以执行INSERT、UPDATE和DELETE等SQL语句。只需将相应的SQL语句赋值给`sql`变量,然后使用`Execute`方法执行即可。 最后,记得在完成操作后关闭连接和记录集对象: ```vba rs.Close conn.Close ``` 通过以上步骤,你可以在Excel VBA使用SQL语句数据库进行交互。特别是对于需要大量数据处理和复杂查询的任务,使用SQL语句可以更高效地操作数据。 ### 回答3: 使用Excel VBA 可以利用SQL 语句来操作数据库。下面是使用Excel VBA SQL 语句的一些基本步骤: 1. 首先需要设置 VBA 对于数据库的引用。在 VBA 编辑器,选择 "工具" -> "引用",勾选 "Microsoft ActiveX Data Objects x.x Library" ,点击确定。 2. 在 VBA 代码使用「ADODB.Connection」对象来建立到数据库的连接。可以使用以下语句创建连接对象: ```vba Dim conn As New ADODB.Connection ``` 3. 使用连接字符串指定数据库的类型和文件路径,例如使用 Microsoft Access 数据库可以使用如下连接字符串: ```vba conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=<路径\文件名.accdb>;" ``` 4. 使用「conn.Open」方法打开数据库连接: ```vba conn.Open ``` 5. 在连接成功后,可以使用「conn.Execute」方法执行 SQL 语句。以下是一个示例: ```vba conn.Execute "UPDATE 名 SET 字段名1='值1' WHERE 字段名2='值2';" ``` 6. 如果想要从数据库检索数据,可以使用「ADODB.Recordset」对象。首先建立一个 Recordset 对象,然后使用「conn.Execute」方法执行 SQL 查询语句,并将结果存储在 Recordset 对象。以下是一个示例: ```vba Dim rs As New ADODB.Recordset rs.Open "SELECT * FROM 名;", conn ``` 7. 在使用完毕后,使用「conn.Close」方法关闭数据库连接: ```vba conn.Close ``` 以上就是使用 Excel VBA SQL 语句的基本步骤。可以根据具体的需求,使用不同的 SQL 语句对数据库进行增删改查的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值