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 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?
  • ¥15 python爬取bilibili校园招聘网站
  • ¥30 求解达问题(有红包)