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

 

转载于:https://www.cnblogs.com/EasyData/archive/2010/02/08/1666026.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值