Linux下SQL Server中VARCHAR类型中文乱码问题解决

项目场景:

往SQL Server数据库中写入数据,定义了其中一个字段类型为VARCHAR类型,该字段类型的值为汉字


问题描述:

遇到的问题:

在写入数据后,通过查询语句来检查写入数据是否正确时,显示出的结果为???的乱码。


原因分析:

通过查询资料得知:默认创建出来的数据库实例默认使用拉丁文编码,这导致了原有项目中 varchar 字段插入中文会乱码的问题。


解决方案:

  1. 通过修改字段类型使其正确显示汉字:将varchar类型修改为nvarchar;修改方法如下

    alter table [tablename] alter column [字段名] nvarchar(200)
    
  2. 通过修改SQL Server的默认排序规则,步骤如下:

     a. 先停止运行sqlserver
    
    sudo systemctl stop mssql-server
    

    b. 进入mssql的bin目录查看mssql-conf 配置信息

    在这里插入图片描述
    c. 然后输入./mssql-conf进行修改排序规则

    在这里插入图片描述
    回车之后输入Chinese_PRC_CI_AS之后再回车,等待修改完成

    d. 重新启动sqlserver

    sudo systemctl start mssql-server
    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值