Execute SQL file with multiple statements separated by “;” using pyodbc

后端 未结 2 1504
天命终不由人
天命终不由人 2021-02-14 15:00

I am currently writing a script to run multiple SQL files using Python, a little background before you mention alternative methods; this is to automate the scripts and Python is

2条回答
  •  春和景丽
    2021-02-14 15:50

    The API in the pyodbc connector (or pymysql) doesn't allow multiple statements in a SQL call. This is an issue of engine parsing; an API would need to completely understand the SQL that it's passing in order for multiple statements to be passed, and then multiple results handled upon return.

    A slight modification to your script like the one below should allow you to send each of your statements individually with separate connectors:

    import os
    import pyodbc
    
    print ("Connecting via ODBC")
    
    conn = pyodbc.connect('DSN=dsn', autocommit=True)
    
    print ("Connected!\n")
    
    inputdir = 'C:\\path'
    
    for script in os.listdir(inputdir):
        with open(inputdir+'\\' + script,'r') as inserts:
            sqlScript = inserts.readlines()
            for statement in sqlScript.split(';'):
                with conn.cursor() as cur:
                    cur.execute(statement)
        print(script)
    
    conn.close()
    

    The with conn.cursor() as cur: opens a closes a cursor for each statement, exiting appropriately after each call is completed.

提交回复
热议问题