1、汉字拼音首字母

/****** Object: UserDefinedFunction [dbo].[fnGetHzPY]
Script Date: 08/16/2018 09:04:47 Description:获取汉字拼音首字母(简拼)
******/
SET ANSI_NULLS ON
GO SET QUOTED_IDENTIFIER ON
GO CREATE FUNCTION [dbo].[fnGetHzPY]
(
@str NVARCHAR()
)
RETURNS NVARCHAR()
AS
BEGIN
DECLARE @WORD nchar(), @PY nvarchar()
SET @PY=''
WHILE LEN(@str) >
BEGIN
SET @WORD = left(@str,)
--如果非汉字字符,返回原字符
SET @PY = @PY +
(CASE
WHEN UNICODE(@WORD) BETWEEN and +
THEN (SELECT top PY FROM (
SELECT 'A' as PY,N'驁' as WORD
UNION all SELECT 'B',N'簿'
UNION all SELECT 'C',N'錯'
UNION all SELECT 'D',N'鵽'
UNION all SELECT 'E',N'樲'
UNION all SELECT 'F',N'鰒'
UNION all SELECT 'G',N'腂'
UNION all SELECT 'H',N'夻'
UNION all SELECT 'J',N'攈'
UNION all SELECT 'K',N'穒'
UNION all SELECT 'L',N'鱳'
UNION all SELECT 'M',N'旀'
UNION all SELECT 'N',N'桛'
UNION all SELECT 'O',N'漚'
UNION all SELECT 'P',N'曝'
UNION all SELECT 'Q',N'囕'
UNION all SELECT 'R',N'鶸'
UNION all SELECT 'S',N'蜶'
UNION all SELECT 'T',N'籜'
UNION all SELECT 'W',N'鶩'
UNION all SELECT 'X',N'鑂'
UNION all SELECT 'Y',N'韻'
UNION all SELECT 'Z',N'咗'
) T
WHERE WORD >= @WORD COLLATE Chinese_PRC_CS_AS_KS_WS
ORDER BY PY ASC)
ELSE @WORD
END)
SET @str = Right(@str,LEN(@str) - )
END
RETURN @PY
END
GO

2、将数字转换为中文数字

/****** Object: UserDefinedFunction [dbo].[fnGetChinaStringA]
Script Date: 08/16/2018 09:11:59
Description:将数字转换成中文数字
******/
SET ANSI_NULLS ON
GO SET QUOTED_IDENTIFIER ON
GO CREATE FUNCTION [dbo].[fnGetChinaNumber]
(
@Word INT
)
RETURNS VARCHAR()
AS
BEGIN
DECLARE @varChinaDateString VARCHAR(),
@varReturn VARCHAR(),
@varWord VARCHAR(),
@I SMALLINT SET @varChinaDateString = '〇一二三四五六七八九'
SET @varWord = CAST(@Word AS VARCHAR)
SET @I =
SET @varReturn = '' WHILE @I <= LEN(@varWord)
BEGIN
SET @varReturn = @varReturn + SUBSTRING(@varChinaDateString, SUBSTRING(@varWord,@I,) + , )
SET @I = @I +
END RETURN @varReturn
END GO

3、函数:将字符串转换为Table数据集

/****** Object: UserDefinedFunction [dbo].[fnParaSplit]
Script Date: 08/16/2018 09:25:38
Description:将字符串转换成表
******/
SET ANSI_NULLS ON
GO SET QUOTED_IDENTIFIER ON
GO CREATE FUNCTION [dbo].[fnParaSplit]
(
@SplitString NVARCHAR(MAX),
@Separator CHAR() = ','
)
RETURNS @SplitStringsTable TABLE
(
[FID] INT IDENTITY(, ),
[Item] VARCHAR()
)
AS
BEGIN
DECLARE @CurrentIndex INT,
@NextIndex INT,
@ReturnText VARCHAR() SET @CurrentIndex = WHILE (@CurrentIndex <= DATALENGTH(@SplitString) / )
BEGIN
SET @NextIndex = CHARINDEX(@Separator, @SplitString, @CurrentIndex) IF(@NextIndex = OR @NextIndex IS NULL)
SELECT @NextIndex = DATALENGTH(@SplitString) / + SET @ReturnText = CONVERT(VARCHAR(), SUBSTRING(@SplitString, @CurrentIndex, @NextIndex-@CurrentIndex)) INSERT INTO @SplitStringsTable
([Item])
VALUES
(@ReturnText) SET @CurrentIndex = @NextIndex +
END RETURN
END GO

附:后续遇到补充。。。

常用Sql 标量值函数的更多相关文章

  1. SQL标量值函数:小写金额转大写

    我们日常开发业务系统中,作为统计报表中,特别是财务报表,显示中文金额经常遇到. 转换大小写的方法有很多,以下是从数据库函数方面解决这一问题. 效果如图: 调用:SELECT dbo.[Fn_Conve ...

  2. SQL标量值函数:返回汉字拼音首拼

    今天遇到一个需求,客户要求在系统客户端选择客户的时候,可以用拼音首拼去快速过滤选择,此时我们在客户表里面加多一个拼音首拼字段CustPY来记录,字段加好了,我们要把所有客户名称的拼音简拼都更新到Cus ...

  3. sql标量值函数,将汉字转化为拼音,无音标

    USE [db_Test]GO SET ANSI_NULLS ONGO SET QUOTED_IDENTIFIER ONGO create function [dbo].[fn_GetPinyin]( ...

  4. SQL表值函数和标量值函数的区别

    SQL表值函数和标量值函数的区别 写sql存储过程经常需要调用一些函数来使处理过程更加合理,也可以使函数复用性更强,不过在写sql函数的时候可能会发现,有些函数是在表值函数下写的有些是在标量值下写的, ...

  5. sql 表值函数与标量值函数

    写sql存储过程经常需要调用一些函数来使处理过程更加合理,也可以使函数复用性更强,不过在写sql函数的时候可能会发现,有些函数是在表值函数下写的有些是在标量值下写的,区别是表值函数只能返回一个表,标量 ...

  6. sql server 中的表值函数和标量值函数

      顾名思义:表值函数返回的是表,而标量值函数可以返回基类型 一.表值函数 用户定义表值函数返回 table 数据类型.对于内联表值函数,没有函数主体:表是单个 SELECT 语句的结果集. 以下示例 ...

  7. sql中的表值函数与标量值函数区别与用法

    通俗来讲: 听名字就知道区别了 表值函数返回的是一张表结果,就和一个select查询语句一样,只不过里面带入了参数或者很复杂:标量值函数返回的只是一个值 一 .表值函数又分为内联函数与多语句函数 (1 ...

  8. sqlserver 表值函数与标量值函数

    除了在我们常用的程序开发中要用到函数外,在sql语句中也常用到函数,不论哪种,思想都没有变,都是为了封装,可复用. 创建的方法和整体结构都大体相同,都少不了函数名,函数的形参,返回值等这些. 一.表值 ...

  9. sqlserver中的表值函数和标量值函数

    顾名思义:表值函数返回的是表,而标量值函数可以返回基类型 一.表值函数 用户定义表值函数返回 table 数据类型.对于内联表值函数,没有函数主体:表是单个 SELECT 语句的结果集. 以下示例创建 ...

随机推荐

  1. 【最短路】【最大流】bzoj3931 [CQOI2015]网络吞吐量

    跑出最短路图,然后把结点拆点跑最大流. #include<cstdio> #include<queue> #include<cstring> #include< ...

  2. 【棋盘DP】【OpenJudge7614】最低通行费

    最低通行费 总时间限制: 1000ms 内存限制: 65536kB [描述] 一个商人穿过一个 N*N 的正方形的网格,去参加一个非常重要的商务活动.他要从网格的左上角进,右下角出.每穿越中间1个小方 ...

  3. ubuntu使用ssh远程登录服务器及上传本地文件到服务器

    1. ubuntu 远程登录   首先你的ubuntu要能够支持ssh,如果不能,自行百度! 打开终端,输入 ssh  root@115.159.200.13(你的服务器的IP地址) 回车就会让你输入 ...

  4. 重写规则为什么要options +followsymlinks

    重写规则为什么要options +followsymlinks Web服务器的Apache安装编译成功mod_rewrite编译成模块,但当我在网站根目录下放了一个.htaccess配置文件,却得到了 ...

  5. java-List集合遍历,删除或增加特定的元素

    1.for(int i=0; i<list.size(); i++) 2.for(Object object : list)  实质调用的 list.iterator() 3.list.iter ...

  6. glib wpa_supplicant Unix上库编译错误解决与总结

    编译Linux下的库是一件痛苦的事情,这里主要阐述glib和wpa_supplicant库的编译,因各自的依赖关系,另外一些库要事先编译.glib依赖libffi和zlib,而wpa_supplica ...

  7. 让你的saga更具有可伸缩性(Scaling NServiceBus Sagas)

    https://lostechies.com/jimmybogard/2013/03/26/scaling-nservicebus-sagas/ 当我们使用NServiceBus sagas (pro ...

  8. 【java】获取解析资源文件的方法

    关于资源文件的读取,有很多种方法,下面补充了多种方法 1.java.util.ResourceBundle 使用java自带的util包下的ResourceBundle类获取,使用方法最简单 //获取 ...

  9. 关于 easyui datagridfilter 中的combox 过滤

    var_activitimodel_datagrid.datagrid({ singleSelect: true, fit: true, striped: true, fitColumns: fals ...

  10. angular get/post 下载 excel

    阅读目录 get请求 post请求 最近做项目,就碰到一个导出excel表格的功能.原本是想利用web前台导出excel的,但是最后因为两点放弃了,第一点,因为中文乱码,第二点,有分页(在前台导出ex ...