我在通过 pymssql 向 SQL Server 发送 unicode 时遇到问题:
In [1]: import pymssql
conn = pymssql.connect(host='hostname', user='me', password='password', database='db')
cursor = conn.cursor()
In [2]: s = u'Monsieur le Curé of the «Notre-Dame-de-Grâce» neighborhood'
In [3]: s
Out [3]: u'Monsieur le Cur\xe9 of the \xabNotre-Dame-de-Gr\xe2ce\xbb neighborhood'
In [4]: cursor.execute("INSERT INTO MyTable VALUES(%s)", s.encode('utf-8'))
cursor.execute("INSERT INTO MyTable VALUES(" + s.encode('utf-8') + "')")
conn.commit()
两个执行语句在 SQL Server 端产生相同的乱码文本:
'Monsieur le Curé of the «Notre-Dame-de-Grâce» neighborhood'
也许我的编码方式或语法有问题。有人建议使用存储过程,但我希望不必走那条路。
这似乎是一个非常相似的问题,没有真正的回应。