sql嵌入python的好处_python执行sql插入语句,为什么这样会报错?

insertintodbo.testvalues(1,2,3,4,5,6,7)能成功插入,每个字段都是unicode字符型。insertintodbo.testvalues(u'中文',1,2,3,4,5,6),这样就会报错,pymssql.ProgrammingError:(102,"I...

insert into dbo.test values(1,2,3,4,5,6,7)能成功插入,每个字段都是unicode字符型。

insert into dbo.test values(u'中文',1,2,3,4,5,6),这样就会报错,pymssql.ProgrammingError: (102, "Incorrect syntax near '\xe9\x87\x8d\xe5\xba\x86'.DB-Lib error message 102, severity 15:\nGeneral SQL Server error: Check messages from the SQL Server\n")

为什么啊?怎么才能不报错呢?

insert into dbo.test values("中文",1,2,3,4,5,6)就行了。但是python操作数据库,这样直接插入数据,数据库能看到数据。但是,如果传参插入,就没数据,也不报错。。。求解

cnn=pymssql.connect(host='192.168.201.210',user='sa',password='123456',port='1433',database='xwqy',charset='utf8')

cursor=cnn.cursor()

sql='INSERT INTO dbo.test VALUES (%s,%s)'

for item in items:

i2=item['regno']

i1=item['entname']

print i1,i2

param=(i1,i2)

cursor.execute(sql,param)

print cursor

cursor.close()

cnn.close()

展开

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值