SqlServer数据库中文乱码问题解决方法

这个问题在网上找了很多资料都没找到真正解决问题的办法,最终去了官网,终于找到问题的答案了,整理出来做个记录。

问题描述:

项目中遇到一个问题,sqlserver中的数据是ok的,结果保存到mysql中是乱码,在确认mysql没问题的情况下开始处理sqlserver的编码。

最开始想到的是,和mysql一样,加一下中文utf-8的设置,结果找了很多都没找到,网上大部分url都是直接写ip和端口,后查的官网这么处理:

下载 JDBC 驱动程序

连接 URL 的一般形式为:

jdbc:sqlserver://[serverName[\instanceName][:portNumber]][;property=value[;property=value]]
jdbc:sqlserver://192.168.128.1:1433;DatabaseName=test;useUnicode=true;characterEncoding=utf-8

其中:

  • jdbc:sqlserver://(必需)称为子协议,且为常数 。

  • serverName(可选)是要连接到的服务器的地址 。 此地址可以是 DNS 或 IP 地址,也可以是本地计算机地址 localhost 或 127.0.0.1。 如果未在连接 URL 中指定服务器名称,则必须在属性集中指定。

  • instanceName(可选)是 serverName 上要连接到的实例 。 如果未指定,则会连接到默认实例。

  • portNumber(可选)是 serverName 上要连接到的端口 。 默认值为 1433。 如果使用默认端口,则无需在 URL 中指定端口及其前面的“:”。

 备注

若要获得最佳连接性能,应在连接到指定实例时设置 portNumber。 这将避免为了确定端口号而与服务器进行往返通讯。 如果同时使用 portNumber 和 instanceName,则会优先使用 portNumber,而忽略 instanceName。

  • property(可选)是一个或多个选项连接属性 。 有关详细信息,请参阅设置连接属性。 可指定该列表中的任何属性。 属性只能用分号(“;”)分隔,且不允许重复。需留意,这个分隔符是分号;,mysql是&,这点注意一下。

出于安全考虑,应避免根据用户输入的内容创建连接 URL。 只应在 URL 中指定服务器名称和驱动程序。 对于用户名和密码值,请使用连接属性集。 有关 JDBC 应用程序安全性的详细信息,请参阅保护 JDBC 驱动程序应用程序

连接示例

使用用户名和密码连接到本地计算机上的默认数据库:

jdbc:sqlserver://localhost;encrypt=true;user=MyUserName;password=*****;

发现这样设置后无效,又继续查看官网信息,发现还需要设置数据库的排序规则:

SQLSERVER默认安装时系统默认的排序规则是拉丁文的排序规则,但一般人在安装时没有考虑到这一点,安装时只是点取下一步,安装完成后,造成了SQL版在使用过程中出现乱码。

解决方法1:

如果是新建数据库,可以在建立数据时指定排序规则,记得选中文简体(Chinese_PRC_CS_AI_WS);如果数据库中已经有数据,则转换 编码会失败

操作步骤

1.右键数据库》属性

2.点击“选项”》修改排序方式

  根据以上操作数据库数据终于正常了,担忧有一点要说一下,如果你以前设置的是默认格式,新设置是Chinese_PRC_CS_AI_WS可能会让你之前的编码变成乱码,这点需留意一下!

扩展1:

sqlserver 建库指定utf-8 修改库为utf-8编码

CREATE DATABASE paas COLLATE Chinese_PRC_CI_AS
GO
ALTER DATABASE paas COLLATE Chinese_PRC_CI_AS
GO

  扩展2:

让ASP和MS SQL SERVER支持UTF-8编码存储多国语言文字

近日在ASP+MS SQL存储UTF-8编码内容的时候,出现乱码的情况,经过查询发现要使SQL SERVER支持UTF-8编码格式,必须做一些修改才可以。

1、确保ASP页面是UTF-8编码的,并在ASP页面顶部声明中使用<%@ LANGUAGE = VBScript CodePage = 65001%>进行编码声明
2、输出的HTML页面中声明字符集:<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
3、在进行URL参数传递的时候,要使用Server.URLEncode()方法进行编码
4、使用JS进行URL参数传递中文的时候,要使用escape进行编码
5、在将UTF-8编码的内容存入SQL SERVER数据库中的时候,要存储的字段必须设置为NVARCHAR类型,SQL语句要在内容前加N表示,如insert into user (name) values (N´&username&´),除id意外的字段都需要加N。

创建连接 URL - JDBC Driver for SQL Server | Microsoft Learn

https://www.zhangshengrong.com/p/ERNnqWYMa5/

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
回答: SQL Server数据库出现乱码的原因可能是由于安装设置时未考虑到默认的排序规则是拉丁文的排序规则,导致在使用过程中出现乱码。\[1\]解决这个问题方法是在安装时选择正确的排序规则或者在已安装的数据库中修改排序规则。另外,还可以通过设置连接URL中的字符编码参数来解决乱码问题。例如,可以在连接URL中添加"useUnicode=true;characterEncoding=utf-8"来指定使用UTF-8编码。\[2\]此外,还需要确保ASP页面是UTF-8编码的,并在页面顶部进行编码声明。同时,在进行URL参数传递时,需要使用相应的编码方法进行编码,如Server.URLEncode()方法或escape方法。另外,在将UTF-8编码的内容存入SQL Server数据库时,需要将相应的字段设置为NVARCHAR类型,并在SQL语句中使用N前缀表示存储的是Unicode字符。\[3\]通过以上方法,可以解决SQL Server数据库乱码的问题。 #### 引用[.reference_title] - *1* [SqlServer数据库中文乱码问题解决](https://blog.csdn.net/u011127019/article/details/51376917)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [SqlServer数据库中文乱码问题解决方法](https://blog.csdn.net/Alex_81D/article/details/130424186)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Alex_81D

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值