{eval=Array;=+count(Array);}
根据我所知道的回答一下这个问题。
虽然mysql和sqlerver均属于关系型数据库,可以执行SQL查询语句,但是mysql数据库并不能直接连接而sqlserver数据库,反之亦然。需要通过“中间人”完成这件事。
如果需要定期的从sqlserver数据库中取出数据放到mysql中,建议使用编程语言实现。该编程语言必须同时有mysql接口和sqlserver接口。由于题主的需求不是很复杂,只是定期的从sqlserver数据中提取数据到mysql数据库,建议考虑使用脚本语言:pyton或者php。
step1:python读取sqlserver的数据
python读取sqlserver数据的数据表的内容需要用到pymssql这个第三方库,可以使用pip安装;
相关代码如下图所示,用于读取sqlserver数据库的内容。
step2:python将读取的数据存入mysql数据库
python操作mysql数据库需要第三方库MySQLdb的支持,可以通过pip的方式安装;
如下显示了通过python执行insert语句写入mysql数据库的操作。
step3:将上述代码定期轮询执行
将上述代码通过定时的方式执行,加入是linux系统,可以使用linux的定时执行任务取执行;
也可以采用python的定时任务去执行,推荐使用第三方库,apscheduler去完成这个工作。下图显示了该库的简单应用,稍加改造就可以完成题主需求的定时任务:
php的实现方法与python的实现方法类似,需要mysql数据库和sqlserver数据库的相关插件,也是如下所示的3个步骤,不同的是需要安装一个简单的web服务,才能运行php代码,推荐使用apache。
step1:php读取sqlserver的数据
step2:php将读取的数据存入mysql数据库
step3:将上述代码定期轮询执行
对于从sqlserver中读取数据,导入mysql中,大家有什么看法呢,欢迎在评论区,留言讨论。
如需更多帮助,请私信关注。谢谢
谢邀~
我的理解题主是要把Mysql中的数据,想办法放到SqlServer中,如果是相同类型的两个数据库,会比较简单一些,但是像这种不同类型的数据库,是没有办法直接连接。
关于这种场景,我谈一谈我能想到的解决方案。
作为程序员,首先能想到的方法就是通过代码来实现,只要能通过代码(Java、Python、PHP等等,什么熟悉用什么)连上两种类型的数据库,做一个定式服务,把数据从Mysql数据库中读取出来,然后插入到SqlServer中即可。
如果数据不多,每次可以做全量的同步:也就是把目标库中的数据全部删除之后,再把所有数据同步过去。
也可以做增量同步,一般是判断数据中的时间戳,读取增量数据进行同步。
有专门的ETL工具,实现这种跨数据库的数据抽取功能,建议数据量比较大的时候,可以考虑ETL工具。可选用的工具很多,比如:Informatica,Kettle,Talend,Navicat Premium等等。
我们项目现在使用的工具是Informatica(不过这个工具是收费的,也比较重量级,我们公司是有购买的),我们项目组也专门招聘了两个做Informatica的程序员,优点就是抽取速度很快,非常得快,缺点也很明显,一是重,二就是学习成本比较高。
如果是要用开源免费的话,可以研究一下Kettle。
你可以使用微软的ACCESS通过ODBC建立到两个库表的链表,在ACCESS中编辑SQL语句来互传数据。我想这也是微软搞ACCESS的初衷,ACCESS打通各种数据库的路径
0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答