这里介绍一种非常高效的方法。就是借助Excel插件SqlCel,这个插件在处理数据上面有很多可取之处,非常值得学习。
比如在Excel中有一个订单ID字段,这个字段总共有2千条记录,现在我们要查询这些订单对应的产品名称。
在Mysql数据库中有一张订单表里面存储了所有订单的详细信息。我们该怎样 *** 作才能最快速地查到每个订单的产品名称呢?
多数人的做法应该是把Excel中的数据导入到Mysql中,然后写一个SQL语句匹配订单表,然后把匹配结果再导出来。这种做法也是可以的,只是非常不方便,单是数据的导入可能就会遇到不少麻烦。用SqlCel处理这个问题就简单了
插件安装之后需要连接到Mysql数据库,点击“数据库连接”下的Mysql,输入连接信息。如下:
连接到数据库之后,点击“SQL查询”进入数据查询编辑器。
这个编辑器和我们平时使用的编辑器一样,可以高亮显示,智能提示,选取执行。同时它还有很多特别的地方,比如定义变量,引用变量、引用Excel单元格、指定数据的来源和去向等。这里我们要说的是它的一个函数RNGTOSTR,这个函数用来将Excel单元格的值转为字符串并拼接到SQL语句中。我们在编辑器中写SQL语句如下:
SELECT DISTINCT PRODUCT_NAME,PRODUCT_ID FROM ORDER_TABLE WHERE PRODUCT_ID IN ('rngtostr([Sheet1!A1:A1000],'\,',true)')
这样一个SQL语句就可以把每一个产品ID对应的产品名称查询到当前Excel中了。
这里面用到了一个函数rngtostr,放一张官网的截图看一下具体的用法
假设你的数据是D:\1.XLS,工作表是:Sheet1则连接串:strConn = "Provider=Microsoft.Jet.OLEDB.4.0Data Source=D:\1.xlsExtended Properties=""Excel 8.0HDR=NOIMEX=1"""
查询语句:strRS = "select * from [Sheet1$]"
将序号列标题和实际的序号均作为数据,按照你的1~30号,来算,记录集的RecordCount的值应该是31,第一行实际上是你的标题列行,使用0~5作为记录集字段索引,以你的实际数据“1 小五 A 31 小小 B”为例,RS(0)的值为1,RS(1)的值为小五。。。。RS(5)的值为B
其他的语法和ACCESS的完全一致。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)