SQL 截取字符串,中文算两个字符的方法

 

--SQL 截取字符串方法,中文算两个字符的方法。

--方法跟水哥学习的,支持一下水哥的博客

--http://hi.csdn.net/link.php?url=http://blog.csdn.net%2Fwufeng4552

--水哥最近谢了好多博客,有时间一定去好好学习
--LEFT() 和SUBSTRING()都是将汉字算一个字符来算的
--如果不计较的话,推荐使用这两个系统函数
IF OBJECT_ID('TB')IS NOT NULL DROP TABLE TB
GO
CREATE TABLE tb (ID INT IDENTITY(1,1),VALUE NVARCHAR(100))
INSERT tb SELECT N'中国abcdefgh'
UNION ALL SELECT N'123 fsd——————'
UNION ALL SELECT N'中国人民'
UNION ALL SELECT N'是中国人,都是炎黄子孙,都是龙人传人'
go
----------------------------创建函数-----------------------
IF OBJECT_ID('f_cut') IS NOT NULL DROP FUNCTION f_cut
GO
CREATE FUNCTION f_cut
(
@s NVARCHAR(50),--你要截取的字符串
@i INT--截取的长度
)
RETURNS NVARCHAR(50)
AS
BEGIN
DECLARE @j INT
DECLARE @a NVARCHAR(100)
SET @j=1
WHILE @j<=@i
 
BEGIN
  
IF UNICODE(SUBSTRING(@s,@j,1)) BETWEEN 19968 AND 40868
   
BEGIN
    
SET @i=@i-1
    
   
END
    
SET @j=@j+1
 
END
RETURN LEFT(@s,@i)
END
GO

------------------查询开始---------------
SELECT id,dbo.f_cut([VALUE],10)FROM tb

-------------------结果------------------
/*


(4 行受影响)
id         
----------- ----------------------------
1           中国abcdef
2           123 fsd———
3           中国人民
4           是中国人,

(4 行受影响)


*/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值