NopCommerce学习:MSSQL 2005 排序规则导致中文编码错误

这两天学习电子商务开源项目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,'&nbsp;','')
    
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

 

posted on 2010-02-08 17:27  迷你软件  阅读(1975)  评论(0编辑  收藏  举报

本网站绝大部分资源来源于Internet,本站所有作品版权归原创作者所有!!如有以下内容:章节错误、非法内容、作者署名出错、版权疑问、作品内容有违相关法律等请及时与我联系. 我将在第一时间做出响应!本站所有文章观点不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。