如@ marr75所建议,请确保已设置charset='utf8'连接。设置字符集暗示了设置use_unicode=True不是严格必需的。
然后确保将unicode对象传递给数据库连接,因为它将使用传递给游标的字符集对其进行编码。如果要传递utf8编码的字符串,则在到达数据库时将对其进行双重编码。
因此,类似:
conn = MySQLdb.connect(host="localhost", user='root', password='', db='', charset='utf8')
data_from_ldap = 'M\xc3\xbcller'
name = data_from_ldap.decode('utf8')
cursor = conn.cursor()
cursor.execute(u"INSERT INTO mytable SET name = %s", (name,))
您也可以尝试通过传递init_command参数来强制连接使用utf8,尽管我不确定是否需要这样做。5分钟的测试应该可以帮助您做出决定。
conn = MySQLdb.connect(charset='utf8', init_command='SET NAMES UTF8')
另外,这一点也不值得一提,因为4.1太旧了,请确保您使用的是MySQL> = 4.1