pymssql 读取nvarchar ntext 报错

  Python 开发一个程序,用pymssql读取sql server 2005 数据库,在使用中出现下面错误

  File "C:"Python25"Lib"site-packages"pymssql.py", line 188, in execute
    raise OperationalError, e[0]
OperationalError: SQL Server message 4004, severity 16, state 1, line 1:

不能用 DB-Library (如 ISQL)或 ODBC 3.7 或更早版本将 ntext 数据或仅使用 Unicode 排序规则的 Unicode 数据发送到客户端。

  找了一下资料, sql server中 ntext 和 nvarchar 采用unicode编码存储内容的, pymssql 读取这种类型字段的时候会报错。

  guid(nvarchar) content(ntext)

  select guid,content from news

  就会报上面的错误

解决方法

(1) 在语句中转换一下数据类型 select convert(varchar(50),guid) as guid, convert(text,content) as content from news

(2) 数据库设计避免使用 nvarchar ntext

 

 


转载于:https://www.cnblogs.com/mapig/archive/2009/03/12/1409402.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值