Cha*_*ame 4 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()
Run Code Online (Sandbox Code Playgroud)
上面的代码没有错误,但是没有创建数据库.
那么如何使用pyodbc创建数据库呢?
非常感谢.
如果您尝试使用连接的默认自动提交值创建数据库,则应收到如下错误.如果您没有看到此错误消息,请尝试更新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)')
Run Code Online (Sandbox Code Playgroud)
打开自动提交以解决连接:
conn = pyodbc.connect("driver={SQL Server};server=serverName; database=master; trusted_connection=true",
autocommit=True)
Run Code Online (Sandbox Code Playgroud)
注意两件事:
autocommit不是连接字符串的一部分,它是传递给connect函数的单独关键字master系统数据库顺便说一句,你可能要检查的@IndexDBName,@mdfFileName以及@ldfFileName正在适当地在你的T-SQL设置.使用您提供的代码,'+ @IndexDBName +'将创建一个名为的数据库.