select * from where 三个条件_VBA学习笔记70: Select语句基础

本文详细讲解了VBA中的Select语句,包括按不同条件筛选数据、筛选方式以及SQL函数的应用,例如数字、字符、日期条件,区间、模糊匹配,以及对筛选结果的格式化和排序等。
摘要由CSDN通过智能技术生成

e940771de2634cb02c22c51b81a1d8da.png

学习资源:《Excel VBA从入门到进阶》第72集 by兰色幻想

这节课来详细讲解Select语句。

Select 字段 from 表 where 条件

例:从sheet1中筛选全部数据。

* 表示全部字符,无条件可以省略where。

Select * from [sheet1$]

如果是对表中特定单元格区域进行查找,可以在[sheet1$]的$后面加单元格区域。


在开讲之前,先在类模块写好打开数据库、复制筛选后的数据到单元格区域和关闭数据库的代码,以便后续可直接调用和增加代码可读性。

类模块命名为数据库,三个属性的名称分别为Excel数据库、Access数据库、执行筛选。

Property Get Excel数据库()
Excel数据库 = "provider=microsoft.jet.oledb.4.0;extended properties=excel 8.0;data source=" & ThisWorkbook.path & "/Database/CangKu.xls"
End Property

Property Get Access数据库()
Access数据库 = "provider=Microsoft.jet.OLEDB.4.0;data source=" & ThisWorkbook.path & "/Database/CangKu.mdb"
End Property

Sub 执行筛选(Mydata As String, sq As String)   '参数有数据库Mydata和地址sq
Dim conn As New Connection
Dim rst As New Recordset

With ActiveSheet 'Sheets("sheet1")
    .Range("a2:i100") = ""     '清空单元格区域
    conn.Open Mydata         '打开数据库
    .Range("a2").CopyFromRecordset conn.Execute(sq)  '把数据复制到单元格中
End With

conn.Close              '关闭数据库
Set conn = Nothing '释放对象

End Sub

本节课所用的数据库是

6e7a3c7cb306b08010f28505a7f4dceb.png

一、按条件筛选

  1. 按条件筛选——数字条件

直接用对比符号,><=

例1:在sheet1中筛选销售单价>100的数据。

Sub 按条件筛选1()
Dim sql As String
Dim data As New 数据库

sql = "Select * from [sheet1$] Where 销售单价 > 100"

data.执行筛选 data.Excel数据库, sql
End Sub

2. 按条件筛选——字符条件

注意:字符条件是文本字符要用单引号括起来。

例2:在sheet1中筛选物品名称为'挡泥板'的数据。

Sub 按条件筛选2()
Dim sql As String
Dim data As New 数据库

sql = "Select * from [sheet1$] Where 物品名称 ='挡泥板'"

data.执行筛选 data.Excel数据库, sql
End Sub

3. 按条件筛选——日期条件

日期条件前后要加#号。

例3:在sheet1中筛选出库日期是2005-1-4的数据。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值