使用Python将数据从MSSQL数据库复制到Postgresql数据库

时间:2011-06-07 11:46:24

标签: python psycopg2 pymssql

我有两个2个数据库。一个用MSSQL,另一个用Postgresql。 我希望我的python脚本每天运行(为此我在linux上使用cron-job)。 来自MSSQL数据库的数据应该复制到Postgresql数据库。我有一个想法,但它不起作用。你可以帮帮我吗???也许我的解决方案完全错了......

这是我的代码:

import pymssql, psycopg2

class DatabaseRequest:

    def __init__(self):
        self.conn1 = pymssql.connect(host='****', user='****', password='****', database='****')
        self.conn2 = psycopg2.connect("dbname='****' user='****' host='*****' password='****'")

        self.cur1 = self.conn1.cursor()
        self.cur2 = self.conn2.cursor()

    def request_proc(self, rows):
        self.cur1.execute("SELECT top 10  tag, site, plant, unit, line, ProcessID AS pid, Count(ReadTime) AS mods \
                        FROM ( \
                        select dateadd(dd, -1, convert(varchar, getDate(),111)) \
                        as tag, ReadTime, processID, subid, PR.Site, PR.Plant, PR.Unit, PR.Line \
                        from FactBarcodeReading BCR with(nolock) \
                        inner join DimProcess PR on BCR.ProcessKey = PR.ProcessKey \
                        where PR.ProcessID IN  (802, 1190, 1800, 3090, 3590, 4390, 4590, 4800, 5000, 5400, 4190) \
                        and ReadTime between dateadd(dd, -1, convert(varchar, getDate(),111)) and dateadd(dd, -0, convert(varchar, getDate(),111)) \
                        ) a \
                        GROUP BY tag, site, plant, unit, line, ProcessID \
                        ORDER BY site, plant, unit, line, ProcessID")

        rows = self.cur1.fetchone()

       # return rows   


    def insert_proc(self):
        self.cur2.execute("INSERT INTO 20091229global (proddate, site, plant, unit, line, pid, mods) \
                        VALUES ('%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s')"
                        % self.cur1.fetchone())


        a = DatabaseRequest()
        print a.insert_proc()

PS:request_proc工作正常。

3 个答案:

答案 0 :(得分:1)

如果代码没有产生错误但插入的记录没有出现在Postgresql数据库中,则很可能需要在执行INSERT语句后添加self.conn2.commit()。这会将每个事务提交到数据库。

根据documentation,还可以启用自动交易。

答案 1 :(得分:0)

你还需要将光标(cur1)传递给insert_proc - >

foreach()

答案 2 :(得分:0)

在试图自己找到答案后才看到这个线程。您可以使用 psycopg2.extras 中名为 execute_values() 的方法。

在文档 https://www.psycopg.org/docs/extras.html 中,您可以在底部附近找到它。只需传递一个字符串变量,然后将该占位符定义为值列表。