【问题标题】:create a database using pyodbc使用 pyodbc 创建数据库
【发布时间】:2014-09-04 16:25:56
【问题描述】:

我正在尝试使用pyodbc 创建一个数据库,但是,我发现这似乎是自相矛盾的,因为 pyodbc 需要先连接到数据库,并且新数据库是在链接的数据库中创建的。如果我错了,请纠正我。

就我而言,我使用以下代码创建了一个新数据库

conn = pyodbc.connect("driver={SQL Server};server= serverName; database=databaseName; trusted_connection=true") 

cursor = conn.cursor()

sqlcommand = """
                   CREATE DATABASE ['+ @IndexDBName +'] ON  PRIMARY 
                    ( NAME = N'''+ @IndexDBName+''', FILENAME = N''' + @mdfFileName + ''' , SIZE = 4000KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB )
                     LOG ON 
                    ( NAME = N'''+ @IndexDBName+'_log'', FILENAME = N''' + @ldfFileName + ''' , SIZE = 1024KB , MAXSIZE = 100GB , FILEGROWTH = 10%)'
             """

cursor.execute(sqlcommand)

cursor.commit()

conn.commit()

上面的代码没有错误,但是没有创建数据库。

那么如何使用 pyodbc 创建数据库呢?

非常感谢。

【问题讨论】:

    标签: python sql database pyodbc


    【解决方案1】:

    如果您尝试使用默认的autocommit 连接值创建数据库,您应该会收到如下错误。如果您没有看到此错误消息,请尝试更新 SQL Server 本机客户端以获得更具描述性的消息:

    pyodbc.ProgrammingError: ('42000', '[42000] [Microsoft][SQL Server Native Client 11.0]
    [SQL Server]CREATE DATABASE statement not allowed within multi-statement transaction.
    (226) (SQLExecDirectW)')
    

    打开自动提交以解决连接:

    conn = pyodbc.connect("driver={SQL Server};server=serverName; database=master; trusted_connection=true",
                          autocommit=True) 
    

    注意两点:

    • autocommit 不是连接字符串的一部分,它是传递给 connect 函数的单独关键字
    • 指定初始连接数据库上下文为master系统数据库

    顺便说一句,您可能需要检查您的 T-SQL 中是否正确设置了 @IndexDBName@mdfFileName@ldfFileName。使用您提供的代码,将创建一个名为 '+ @IndexDBName +' 的数据库。

    【讨论】:

    • 那么您并没有真正解释自动提交的实际作用?
    • @NoName - 由于 context 是 SQL Server 的 ODBC 驱动程序,Transactions in ODBC 可能有助于了解详细信息。
    猜你喜欢
    • 2019-09-13
    • 1970-01-01
    • 2021-12-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多