我正在尝试将数据帧写入 SQL Server 表中。我的代码:
conn = pymssql.connect(host="Dev02", database="DEVDb")
cur = conn.cursor()
query = "INSERT INTO dbo.SCORE_TABLE VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s)"
cur.executemany(query, df_sql)
conn.commit()
cur.close()
conn.close()
的尺寸df_sql
is (5860, 20)
即数据框中的列数与 SQL Server 表中的列数相同。我仍然收到以下错误:
ValueError:sql 中的占位符多于可用参数
更新如下
根据其中一条评论,我尝试使用turbodbc
如下:
conn = turbodbc.connect(driver="{SQL Server}", server="Dev02", Database="DEVDb")
conn.use_async_io = True
cur = conn.cursor()
query = "INSERT INTO dbo.STG_CONTACTABILITY_SCORE VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"
cur.executemany(query, df_sql.values)
cur.commit()
cur.close()
conn.close()
我收到以下错误:
ValueError:具有多个元素的数组的真值是
模糊的。使用 a.any() 或 a.all()
我不明白。这里出了什么问题。我懂了df_sql.values
我没有发现任何问题。
ndarray的第一行如下:
[nan 'DUSTIN HOPKINS' 'SOUTHEAST MISSOURI STATE UNIVERSITY' 13.0
'5736512217' None None 'Monday' '8:00AM' '9:00AM' 'Summer' None None None
None '2017-12-22 10:39:30.626331' 'Completed' None '1-11KUFFZ'
'Central Time Zone']