NopCommerce学习:MSSQL 2005 排序规则导致中文编码错误
2020-02-02 06:32
776 查看
这两天学习电子商务开源项目NopCommerce,她的确做的很好,在电子商务开源项目中应该算是很棒的.
官方站点: http://www.nopcommerce.com/
中文社区:http://www.nopchina.com/
但是,里面博客部分,默认是将整篇文章内容一起加载到页面,感觉不是很好,于是,用SQL过滤文章内容中的HTML标签后,返回前150个字符(学习园子首页),SQL函数如下:
-- 过滤HTML标签
CREATE FUNCTION [dbo].[SQL_Filter](@input varchar(4000))
RETURNS varchar(4000)
AS
BEGIN
declare
@Result varchar(4000),
@start int,
@end int,
@len int
set @input = @input + '<>'
set @Result = ''
set @len=len(@input)
set @start = charindex('<',@input,1)
set @end = charindex('>',@input,@start)
while(@start<@end)
begin
if(@start<>1)
set @Result = @Result + substring(@input,1,@start-1)
set @len = @len - @end
set @input = substring(@input,@end+1,@len)
set @start = charindex('<',@input,1)
set @end = charindex('>',@input,@start)
end
RETURN replace(@Result,' ','')
END
但运行后发现了一个问题,如果文章内容中包含中文,则编码成了问号(?)。
然后测试了不同几个函数, 结果一致,中文编码错误。
应此判断,应该为数据库设置问题,检查后发现,该数据库的排序规则不是:Chinese_PRC_CI_AS (企业管理器 - 数据库属性 - 常规 - 维护 - 排序规则)。
知道原因后,开始解决问题,重启SQL服务,执行以下语句(将排序规则更改为:Chinese_PRC_CI_AS):
alter database NopCommerce collate Chinese_PRC_CI_AS
但由于数据库里已有对象使用了数据库排序规则,应此出现如下错误:
消息 5075,级别 16,状态 1,第 1 行
对象'CK_Nop_ShoppingCart_Quantity' 依赖于 数据库排序规则。
消息 5075,级别 16,状态 1,第 1 行
对象'NOP_splitstring_to_table' 依赖于 数据库排序规则。
消息 5072,级别 16,状态 1,第 1 行
ALTER DATABASE 失败。无法将数据库 'NopCommerce' 的默认排序规则设置为 Chinese_PRC_CI_AS。
最终解决办法 - 不知道该解决办法会不会影响数据库原有结构,而导致程序可能发生异常?(以下代码由网友 阿枫 提供帮助):
use NopCommerce
--删掉对象
ALTER TABLE [dbo].[Nop_ShoppingCartItem] drop constraint [CK_Nop_ShoppingCart_Quantity]
drop function [dbo].[NOP_splitstring_to_table]
go
--更改数据库默认语言
alter database NopCommerce collate Chinese_PRC_CI_AS;
go
--新建对象
ALTER TABLE [dbo].[Nop_ShoppingCartItem] WITH CHECK ADD CONSTRAINT [CK_Nop_ShoppingCart_Quantity] CHECK (([quantity]>(0)))
GO
ALTER TABLE [dbo].[Nop_ShoppingCartItem] CHECK CONSTRAINT [CK_Nop_ShoppingCart_Quantity]
GO
CREATE FUNCTION [dbo].[NOP_splitstring_to_table]
(
@string NVARCHAR(1000),
@delimiter CHAR(1)
)
RETURNS @output TABLE(
data NVARCHAR(256)
)
BEGIN
DECLARE @start INT, @end INT
SELECT @start = 1, @end = CHARINDEX(@delimiter, @string)
WHILE @start < LEN(@string) + 1 BEGIN
IF @end = 0
SET @end = LEN(@string) + 1
INSERT INTO @output (data)
VALUES(SUBSTRING(@string, @start, @end - @start))
SET @start = @end + 1
SET @end = CHARINDEX(@delimiter, @string, @start)
END
RETURN
END
转载于:https://www.cnblogs.com/EasyData/archive/2010/02/08/1666026.html
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- NopCommerce学习:MSSQL 2005 排序规则导致中文编码错误
- [MSSQL]排序规则的 中文版MSSQL下开发的存储过程在布署到英文MSSQL时的一个运行错误
- [Unity3D]关于中文注释导致的文件编码错误问题
- sqlserver中的数据库排序规则(Collation)指定错误使中文变成问号
- 关于中文注释导致的文件编码错误问题
- 关于MSSql 2005 数据库的排序规则
- ruby 文件中文编码问题 导致passenger start错误的解决方法
- [Unity3D]关于中文注释导致的文件编码错误问题
- 中文系统下,UTF-8编码文本文件读取导致的错误
- Mysql创建数据库的排序规则 中文 选择哪种编码
- MSSQL中文排序规则设置
- sql server 2005 排序规则与大小写敏感 (sql server2005学习笔记1)
- MSSQL中文排序规则设置
- SQL SERVER 2005 排序规则引发的中文乱码 解决方法
- 转:从开源项目学习 C 语言基本的编码规则
- 为什么ASCII是7位(导致各家编码的128~256字符都不同,给我带来很多困惑)——在标准ASCII中,其最高位(b7)用作奇偶校验位,附ASCII每个控制符的中文解释
- FCKeditor 2.6 编码错误导致修改的内容出现乱码的解决方法
- 排序规则导致like出错及纠正
- vs2013 c++代码内出现中文导致编译错误
- MYSQL创建数据库时候直接指定编码和排序规则