作者: 左其盛 发表于 2010-07-18 22:30 原文链接 阅读: 131 评论: 0
最近在做的一个项目遇到这么一个问题:需要把一个字符串格式的卡号转换为bigint格式的卡号。t-sql自带的isnumeric函数不能用。它认为合格的数字不一定是bigint,比如一些带小数点的数字,科学计数的数字。上网搜,中文资料中没发现有帮助的,在sqlservercentral上发现有人写过这个函数了。关键的算法就是charindex + substring循环,一个一个看有没有不合法的字符。文章的评论中有人说可以用patindex函数,更快。不过用了这两个都解决不了全角数字的问题,他们都认为全角数字是合法的数字,当然实际转换为bigint的时候会报错。
又上网搜了搜,注意到了COLLATE关键字。一般的解释是它可以指定排序规则。可以改变的规则有大小写、重音、假名(日语才有)、全角半角。中文系统中很少用到这个关键字。一般就用默认的大小写不敏感。我这里想区分全角半角,必须用COLLATE关键字。可以这么用:charindex(substring(@s, @i, 1), '0123456789' COLLATE Chinese_PRC_CS_AS_KS_WS),其中COLLATE后面的参数中Chinese_PRC指定字符集所使用的代码页(其实就是所用的语言),后面最多可以跟四个×s,S表示敏感,对应的I表示不敏感。比如Chinese_PRC_CS_AS_KS_WS表示是简体中文,大小写敏感(CS),重音敏感(AS,这个对汉语没意义),区分假名类型(KS,这个对汉语也没意义),区分全角半角(KS),Chinese_PRC_CI_AI表示简体中文,大小写不敏感,重音不敏感,不区分假名类型,不区分全角半角。后两个参数忽略掉就表示否定。当然还可以直接指定二进制排序,全角半角的问题就自然解决了,而且二进制排序还更快一些:charindex(substring(@s, @i, 1), '0123456789' COLLATE Chinese_PRC_BIN)
因此,理论上这个判断字符串是否为bigint的问题的核心算法有四种解决方案:
charindex(substring(@s, @i, 1), '0123456789' COLLATE Chinese_PRC_CS_AS_KS_WS)
charindex(substring(@s, @i, 1), '0123456789' COLLATE Chinese_PRC_BIN)
patindex('%[^0-9]%',@s COLLATE Chinese_PRC_CS_AS_KS_WS )
patindex('%[^0-9]%',@s COLLATE Chinese_PRC_BIN )
不过实验发现第三种不能解决问题,仍然认为全角数字是合法的数字。看微软msdn文档,上网搜都没有找到答案。其他三种都可以。理论上最后一种最快。
下面是完整的函数的代码:
/*
-- Tests pass isnumeric AND fail IsBigInt AND fail cast(vc as bigint)
-- range
SELECT IsNumeric('-9223372036854775809'), dbo.IsBigInt('-9223372036854775809')
SELECT IsNumeric('9223372036854775808'), dbo.IsBigInt('9223372036854775808')
-- invalid chars
SELECT IsNumeric('-5d2'), dbo.IsBigInt('-5d2')
SELECT IsNumeric('-5e2'), dbo.IsBigInt('-5e2')
SELECT IsNumeric('+3,4'), dbo.IsBigInt('+3,4')
SELECT IsNumeric('+3.4'), dbo.IsBigInt('+3.4')
-- pass this strange case
SELECT IsNumeric('00000000000000000000000000001'), dbo.IsBigInt('00000000000000000000000000001')
*/
IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'dbo.IsBigInt') AND type IN (N'FN', N'IF', N'TF', N'FS', N'FT'))
DROP FUNCTION dbo.IsBigInt
GO
CREATE FUNCTION dbo.IsBigInt (@a varchar(30))
returns bit
AS
BEGIN
-- Submitted to SqlServerCentral by William Talada
DECLARE
@s varchar(30),
@i int,
@IsNeg bit,
@valid int
-- assume the best
SET @valid = 1
SET @IsNeg=0
SET @s = ltrim(rtrim(@a))
-- strip OFF negative sign
IF len(@s) > 0
AND LEFT(@s, 1) = '-'
BEGIN
SET @IsNeg=1
SET @s = RIGHT(@s, len(@s) - 1)
END
-- strip OFF positive sign
IF len(@s) > 0
AND LEFT(@s, 1) = '+'
BEGIN
SET @s = RIGHT(@a, len(@a) - 1)
END
-- strip leading zeros
while len(@s) > 1 and left(@s,1) = '0'
set @s = right(@s, len(@s) - 1)
-- 19 digits max
IF len(@s) > 19 SET @valid = 0
-- the rest must be numbers only
--SET @i = len(@s)
--WHILE @i >= 1
--BEGIN
----IF charindex(substring(@s, @i, 1), '0123456789' COLLATE Chinese_PRC_CI_AS_WS ) = 0 SET @valid = 0
-- IF charindex(substring(@s, @i, 1), '0123456789' COLLATE Chinese_PRC_BIN ) = 0 SET @valid = 0
-- SET @i = @i - 1
--END
--if patindex('%[^0-9]%',@s COLLATE Chinese_PRC_CI_AS_WS )>0
if patindex('%[^0-9]%',@s COLLATE Chinese_PRC_BIN )>0
set @valid=0
-- check range
IF @valid = 1 AND len(@s) = 19
BEGIN
IF @isNeg = 1 AND @s > '9223372036854775808' SET @valid = 0
IF @IsNeg = 0 AND @s > '9223372036854775807' SET @valid = 0
END
RETURN @valid
END
go
评论: 0 查看评论 发表评论
百度期待您的加盟
最新新闻:
· 微软不为外界所知的十件趣事(2010-07-18 22:58)
· 中国第2季搜索引擎市场规模达26亿 百度破70%(2010-07-18 22:54)
· Facebook用户数下周达5亿 邀请用户共享故事(2010-07-18 22:49)
· 开源的可视化编辑器 KindEditor 3.5.1 发布(2010-07-18 22:35)
· WordPress 陷入开源‘边界’之争(2010-07-18 17:47)
编辑推荐:揭秘Facebook背后的那些软件
网站导航:博客园首页 个人主页 新闻 闪存 小组 博问 社区 知识库
分享到:
相关推荐
T-SQL还包含各种内置函数,如数学函数、字符串函数、日期时间函数等,用于处理特定任务。 5. 数据类型:理解数据类型是使用任何编程语言的基础,T-SQL提供了一系列的数据类型来适应不同类型的值,如整数、浮点数、...
T-SQL,全称为Transact-SQL,是由Microsoft公司为SQL Server数据库管理系统设计的一种扩展的SQL语言。它不仅包含了标准SQL的功能,还添加了许多特有特性,以增强数据库管理和应用程序开发的灵活性和效率。 **T-SQL...
首先,我们来看标题提到的SQL语句,它创建了一个名为`dbo.F_Get_No`的用户定义函数,这个函数接受一个`varchar(100)`类型的参数`@No`,并返回一个`bigint`类型的值,即字符串中的纯数字部分。 函数的核心逻辑在于`...
在T-SQL中,数据类型是定义数据结构和表达式的基础,它们决定了数据的存储方式、占用的空间以及处理数据的规则。SQL Server 2000 提供了一系列丰富的数据类型,以满足各种不同应用场景的需求。 1. **整数数据类型**...
**SQL Server 2008 中的 T-SQL 数据类型** 在 SQL Server 2008 中,数据类型是至关重要的概念,它们定义了数据库中存储数据的种类和格式。理解并正确选择数据类型对于创建高效、可靠的数据库至关重要。T-SQL ...
在IT领域,特别是数据库管理与优化中,使用T-SQL语句进行跟踪是十分关键的技能之一。T-SQL(Transact-SQL)是Microsoft SQL Server使用的SQL方言,它不仅支持标准SQL的功能,还提供了额外的编程功能。通过T-SQL,...
### SQL字符串转换语句大全详解 #### 一、概述 在数据库操作中,字符串处理是一项常见且重要的功能。SQL提供了丰富的内置函数来帮助用户完成字符串的格式化与转换任务,这些函数可以极大地提高数据处理效率并简化...
T-SQL提供了丰富的内置函数,如数学函数、字符串函数、日期/时间函数等,用于处理数据计算、字符串操作和日期时间转换等任务。此外,还可以创建自定义函数以满足特定业务需求。 总结来说,T-SQL是SQL Server中的...
在T-SQL中,数据类型是定义变量、常量、函数参数和表列的基础,它们决定了数据如何被存储和处理。 1. 数值型数据类型: - INTEGER (INT):4字节,存储范围-2,147,483,648到2,147,483,647。 - SMALLINT:2字节,...
根据给定的信息,本文将详细解释如何将IPv4与IPv6地址从字符串形式转换为`BigInteger`数字形式,以及反向操作的过程。 ### IPv4与IPv6简介 #### IPv4 IPv4(Internet Protocol Version 4)是互联网协议的第四版,...
### T-SQL创建与修改表的操作实验解析 #### 实验背景 本次实验旨在通过实际操作加深对T-SQL的理解,并熟练掌握使用T-SQL进行表的创建与修改的方法。实验内容涉及了创建数据库、创建表、添加约束以及修改表结构等...
BIN(N) 函数返回二进制值 N 的一个字符串表示,在此 N 是一个长整数(BIGINT)数字,这等价于 CONV(N,10,2)。如果 N 是 NULL,返回 NULL。 mysql> select BIN(12); -> '1100' 5. OCT(N) 函数 OCT(N) 函数返回八进制...
创建自定义MD5函数的过程通常涉及编写T-SQL代码,利用内置的转换和字符串处理函数。在SQL Server中,可以使用`HASHBYTES`函数来计算哈希值,但默认不支持MD5算法,所以我们需要通过转换方式实现。 以下是创建自定义...
对于初学者来说,掌握 **T-SQL** (Transact-SQL) 是必不可少的一步。T-SQL 是 SQL Server 的专有扩展语言,用于查询、更新和管理 SQL Server 数据库。本文将详细介绍 SQL Server 2008 中 T-SQL 的基础知识。 ### T-...
在SQL Server中,T-SQL(Transact-SQL)是用于管理和操作数据库的语言,它包含了丰富的数据类型,用于表示各种不同类型的数据。以下是T-SQL中常见的数据类型及其详细说明: 1. **数值类型**: - **Int**: 4个字节...
首先,我们关注到这个压缩包的名字“flink-sql-demo-data-part2.tar.gz”,这暗示了它是Flink SQL演示项目的一部分,可能用于展示或测试特定的SQL查询功能。通常,这样的数据集会包含模拟真实业务场景的数据,帮助...
在实际应用中,我们经常需要连接两个字符串。SQL Server、Oracle、DB2和IQ都支持连接字符串的语句。例如,在SQL Server中,我们可以使用以下语句连接两个字符串: ``` Select 'Hello' + 'Toone' ``` 空值转换 在...
- `STR`和`CONVERT`在SQL Server中实现数字到字符串的转换。 4. **其他行级别的函数**: - `DECODE`在Oracle中用于条件判断,SQL Server中可使用`CASE`或`IIF`表达式替代。 - `COALESCE`在Oracle和SQL Server中...
### 达梦SQL语言使用手册知识点详述 #### 第1章 结构化查询语言DM_SQL简介 ##### 1.1 DM_SQL语言的特点 DM_SQL(达梦SQL)是达梦数据库管理系统提供的一种标准的SQL语言实现,具有以下特点: 1. **兼容性**:高度...