python – 使用pyodbc创建数据库
发布时间:2020-12-20 11:37:35 所属栏目:Python 来源:网络整理
导读:我正在尝试使用pyodbc创建一个数据库,但是,我发现它似乎是矛盾的,因为pyodbc需要首先连接到数据库,并且新的数据库是在链接的数据库中创建的.如果我错了,请纠正我. 在我的例子中,我使用以下代码来创建一个新的数据库 conn = pyodbc.connect("driver={SQL Serv
我正在尝试使用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创建数据库呢? 非常感谢. 解决方法
如果您尝试使用默认的
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函数的单独关键字 另外,您可能希望检查@IndexDBName,@ mdfFileName和@ldfFileName是否在T-SQL中正确设置.使用您提供的代码,将创建名为“@IndexDBName”的数据库. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |