使用pyodbc创建数据库

时间:2014-09-04 16:25:57

标签: python sql database pyodbc

我正在尝试使用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创建数据库?

非常感谢。

1 个答案:

答案 0 :(得分:7)

如果您尝试使用默认的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 +'的数据库。