python执行sql插入语句,为什么这样会报错? 22

insertintodbo.testvalues(1,2,3,4,5,6,7)能成功插入,每个字段都是unicode字符型。insertintodbo.testvalue... 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()
展开
 我来答
day忘不掉的痛
2016-05-20 · 知道合伙人数码行家
day忘不掉的痛
知道合伙人数码行家
采纳数:62646 获赞数:223941
本人担任公司网络部总经理多年,有充足的网络经验、互联网相关知识和资讯。

向TA提问 私信TA
展开全部
要看你的数据库里存的是什么格式的,如果是unicode的话:
sql="select * from t.branch where name='河南'".decode('utf8')
如果是gb系列编码的话:
sql="select * from t.branch where name='河南'".decode('utf8').encode('gb18030')
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
玩转数据处理
2016-05-18 · 数据处理,Python,dotnet
玩转数据处理
采纳数:1613 获赞数:3794

向TA提问 私信TA
展开全部
cursor.execute(sql%param)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式