python sqlserver报错_在python中使用to\u sql函数将dataframe插入到Sqlserver DB时出错

我正在尝试使用将pandas数据帧df插入到sqlserverdb中dataframe.to\u sql功能。但我发现以下错误:

源代码:import pyodbc

import sqlalchemy

import urllib

df #sample dataframe

params = urllib.parse.quote_plus("DRIVER={SQL Server};SERVER=GIRSQL.GIRCAPITAL.com;DATABASE=Tableau;UID=SQL_User;PWD=pass")

engine = sqlalchemy.create_engine("mssql+pyodbc:///?odbc_connect=%s" % params)

engine.connect()

df.to_sql(name='[Tableau].[dbo].[Test table]',con=engine, index=False,

if_exists='append')

错误:File "C:\Users\Arvinth\sqlalchemy\engine\default.py", line 470, in do_execute

cursor.execute(statement, parameters)

sqlalchemy.exc.ProgrammingError: (pyodbc.ProgrammingError) ('42000', "[42000] [Microsoft][ODBC SQL Server Driver][SQL Server]Incorrect syntax near 'INTEGER'. (102) (SQLExecDirectW)") [SQL: '\nCREATE TABLE [[Tableau].[dbo].[Test table]] (\n\t[A] INTEGER NULL, \n\t[B] INTEGER NULL, \n\t[C] INTEGER NULL\n)\n\n']

示例数据帧:

^{pr2}$

有谁能帮忙解决这个问题吗。在

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值