xiaotoly 2017-09-05 12:48 采纳率: 0%
浏览 969
已结题

SQL SERVEY 2005表的字符数据最后一个字节乱码(汉字乱码),显示为问号:?(0x3F)

问题:
系统:GBK字符集, 数据库:SQL SERVEY 2005
定义的表数据举例:
CREATE TABLE [dbo].EXAMPLE_TEST
(
EXAMPLE_PAR varchar (32) COLLATE Chinese_PRC_BIN NOT NULL,
其它字段
)
后台写入表数据超过32字节,程序会强制截取前32位字节送给EXAMPLE_PAR字段,如果前面有英文等单个字节则最后一个汉字将会截位,但是EXAMPLE_PAR显示的内容有时正确有时错误如下(出现错误概率万分之几甚至更小,有的服务器都没出现,数据量都是百万以上):
青海长云暗雪山-孤城遥望玉门关正?
青海长云暗雪山-孤城遥望玉门关信
青海长云暗雪山a孤城遥望玉门关正?
青海长云暗雪山a孤城遥望玉门关信

个人推断:刚开始以为前端传入的,后来发现有的表只有后台才写入也会出现这样的问题,就是拼接字符串写入数据库这一个步骤,程序没有其它错误,就是会出现上面截位汉字的情况,但是存入数据库结果又不一致,要有问题肯定都有,同样的情况有时写入数据库有问号有时没有,所以认为数据库默认编码处理有问题,但是又找不到原因。
  希望遇到过此类问题或知道原因的大神指点一二...

  • 写回答

3条回答

  • threenewbee 2017-09-06 01:29
    关注

    用nvarchar,而且不要32,要大一些

    评论

报告相同问题?

悬赏问题

  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记