如何通过Excel查询MySQL数据库

如何通过Excel查询MySQL数据库,第1张

这里介绍一种非常高效的方法。就是借助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,放一张官网的截图看一下具体的用法

1、先在mysql管理工具上面新建一个表,也可以用mysql命令创建。表的字段要和EXECL上对应的数据相对应。

2、使用mysql的第三方管理工具,如Navicat

for

MySQL,打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择import

wizard

,有汉化版本的更明确,在d出一个选择界面,直接选择excel

file文件。

3、点击next(下一步),选择对应的excel文件确定,然后再下面选择表中对应的sheet。

4、选择后,再点击next

(此步骤也是关键步骤),需要注意2点:

1:filed

name

row

就是字段所在excel中的位置,也就是第几行(简单办法,一般就是英文对应的那一列)。2:first

data

row(从哪一行开始执行),如果没有表头名称,直接就是数据的,就是1。

5、再点击next,选择

target

table

目标对应的数据库,选择要导入到哪个数据库中表中。

6、如果到上面一步没有问题的话,默认next到最后就行了。然后打开Mysql表就能看到数据跟excel表中的一样数据了。

步骤如下:

1,首,需要在mysql管理工具上面新建一个表,也可以用mysql命令创建,表建立完成之后,你需要将表中的字段名字告诉给填写excel表的人员.

2,打开excel表,按照程序提供的字段填写相应的数据.此时注意下面几点:名字,比如用红色标示出来了)需要跟程序提供的一样,其他的描述,表头可以不写都行.

3,使用的mysql管理工具是Navicat

for

MySQL,打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择import

wizard

,有汉化版本的更明确.d出一个选择界面,我们选择excel

file文件,

4,点击next(下一步),选择自己对应的excel文件就行,然后再下面选在我们的文件内容在哪一个sheet中,也就是你的内容写在excel什么地方,这点需要注意,也是关键的地方,我的内容在sheet3中,所以我选择sheet3

,

5,

点击next

(此步骤也是关键步骤),需要注意2点:

1:filed

name

row

就是你的字段所在excel中的位置,也就是第几行(简单办法,一般就是英文对应的那一列).2:first

data

row(从哪一行开始执行),数据从哪一行开始呢,我这里选择的是3,4.

6,点击next

选择

target

table

目标对应的数据库,选择你要导入到哪个数据库中表中.

7,如果到上面一步没有问题的话,我们默认next到最后

就行了.然后打开表就能看到数据跟excel表中的一样.


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5920787.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-08
下一篇 2023-03-08

发表评论

登录后才能评论

评论列表(0条)

保存