数字排序转变为字母排序

在工作由于业务的特殊需求,需要把一些数据记录排序序号,转化为英文字母的顺序。如:1,2,3,4,5,6 转化为A,B,C,D,E.....等一系列的顺序。

起初是用循环的,但要变成易与扩展,适应尽量多的排序,从而形成多的英文字母排序。所以几经改良,用了递归来调用,以此来记录下。

主要sql实现的

----------------------------------------------
--Version 20170309
--Create by:shoupifeng
--Craate on :2017-03-09
--主要根据数据字排序数字,转化为大写英文字母顺序
--如:1,2,3,4,5 转化为 A,B,C,D,E
--0是不支持转化的
--SELECT DBO.FN_NUMBER_TO_LETTER(1)
-----------------------------------------------
CREATE FUNCTION [dbo].[FN_NUMBER_TO_LETTER](@ROWNUM int)
RETURNS NVARCHAR(MAX)
AS
BEGIN
DECLARE @RESULT NVARCHAR(MAX);
SET @RESULT=‘‘
IF @ROWNUM>0
BEGIN
DECLARE @YUSHU INT;
DECLARE @SHANG INT;
SET @YUSHU= @ROWNUM%26
SET @[email protected]/26

IF @YUSHU=0
BEGIN
SET @[email protected]+CHAR(90)
SET @[email protected]
END;
ELSE
BEGIN
SET @[email protected]+CHAR([email protected])
END;
IF @SHANG>0
BEGIN
SET @RESULT=dbo.[FN_NUMBER_TO_LETTER](@SHANG)[email protected]
END;
END;
ELSE
BEGIN
SET @RESULT=CAST(@ROWNUM AS NVARCHAR(20))
END;

RETURN @RESULT;

END

GO

时间: 2024-10-06 12:48:12

数字排序转变为字母排序的相关文章

086-PHP数组按数字排序和按字母排序

<?php $arr=array(2,54,167,'a','A','12'); //定义一个数组 echo '数组排序之前的信息:<br />'; print_r($arr); //输出数组的信息 echo '<br />数组普通排序之后的信息:<br />'; sort($arr); //对数组进行排序 print_r($arr); echo '<br />数组作为数字排序之后的信息:<br />'; sort($arr,SORT_NU

联系人列表字母排序索引(三)

也是忙忙碌碌好几天,今天又有时间了,继续这个文章的编写.今天是这篇文章的最后一部分.主要内容包括以下几点: 1.将中文名字转化成拼音,并提取首字母,进行排序. 2.实现分组列表Adapter模板. 3.将列表与索引结合在一起. pinyin4j是一个将中文转化成拼音的高效工具,我的源码中带了这个依赖包.通过这个工具,可以先获取一个中文的拼音. public static String getLetter(String name) { StringBuilder sb = new StringBu

php按照中文首字母排序

1> 网络上很多php的工具类可以将汉字转为拼音: 2> 将拼音进行排序即可 另一种则是类似mysql转码方式: 1 foreach ($array as $key=>$value) 2 { 3 $new_array[$key] = iconv('UTF-8', 'GBK', $value); 4 } 1 foreach ($array as $key=>$value) 2 { 3 $new_array[$key] = iconv('UTF-8', 'GBK', $value);

中文首字母 排序

因项目需要对通讯录中的联系人进行排序,需要对中文字符进行拼音转换.其实这个转换并没有想象中的那么难(因为我们只是把中文转为拼音首字母而已,比如“王”转换为字母w就可以了,而不需要转换为完整的拼音wang).对此,我们找到了一个简便的解决办法:一个老外(代码中签名的作者叫George)用c语言写了一个pinyinFirstLetter函数用于获取中文拼音首字母. 这个函数主要基于一个巨大的c语言char数组,把unicode字符集中所有中文的拼音首字母都映射进去了. pinyinFirstLett

按首字母排序汉字

项目中需要一个选择城市名的功能,具体的数据可以到国家统计局的网站上查,直接搜索也有很多,比如http://blog.jjonline.cn/phptech/172.html. 数据是有了,可是汉字怎么按照字母排序呢? 一.前端 js 处理 var a = ["上海","大连","北京","拉萨","天津"]; //返回["北京", "大连", "拉萨&quo

按拼音首字母排序

<?php $temp = array(); // 按拼音首字母排序 foreach($res as $key=>$val){ $index = $this->sortByPinyin($val['note_name']); $temp[$index][] = $val; //先用中间变量数组,根据字母A B C..装着集合在一起的 } $list = array(); foreach($temp as $k=>$v){ $list[$k]['index'] = $k; $list

Java编程实现中英混合字符串数组按首字母排序的方法

在Java中对于字符串数组的排序,我们可以使用Arrays.sort(String[])方法很便捷的进行排序.例如: ? 1 2 3 4 5 6 7 String[] arrays = new String[] { "gyu", "sdf", "zf", "大同", "收到", "地方", "三等分", "的人", "反对高铁"

三道习题(1、将单词表中由相同字母组成的单词归成一类,每类单词按照单词的首字母排序,并按 #每类中第一个单词字典序由大到小排列输出各个类别。 #输入格式:按字典序由小到大输入若干个单词,每个单词占一行,以end结束输入。)

#coding=gbk ''' 1.将单词表中由相同字母组成的单词归成一类,每类单词按照单词的首字母排序,并按 #每类中第一个单词字典序由大到小排列输出各个类别. #输入格式:按字典序由小到大输入若干个单词,每个单词占一行,以end结束输入. #cinema #iceman #maps #spam #aboard #abroad #end #输出格式:一类单词一行,类别间单词以空格隔开. #aboard abroad #cinema iceman #maps spam ''' result=[]

localeCompare按首字母排序汉字

sort() 方法用于对数组的元素进行排序. 如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字.比较函数应该具有两个参数 a 和 b,其返回值如下: 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值. 若 a 等于 b,则返回 0. 若 a 大于 b,则返回一个大于 0 的值. <script type="text/javascript"> function sortNum