正解SQLSERVER 2005 sql排序(按大小排序)
更新时间:2021年09月18日 10:07:23 投稿:mdxy-dxy
Insus.NET写了一个函数,可以方便以后的扩展,如果数值出现TB或是或更高时,可以只改这个函数即可。
今天在论坛上看到一个问题,如下:
解决这个问题,Insus.NET写了一个函数,可以方便以后的扩展,如果数值出现TB或是或更高时,可以只改这个函数即可。
复制代码 代码如下:
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER FUNCTION [dbo].[udf_OrderLimitSize]
(
@Ov NVARCHAR(30)
)
RETURNS decimal(18,6)
AS
BEGIN
--如果长度少于等于2的数值为返回NULL
IF (LEN(@Ov) <= 2)
RETURN NULL
--宣告两个变量
DECLARE @v DECIMAL(18,6),@n DECIMAL(18,6)
--判断最后两位数是否为下面这些单位
IF (RIGHT(@Ov,2) NOT IN ('TB','GB','MB','KB'))
RETURN NULL
--去掉最后两位数之后,把值转为DECIMAL数据类型
SET @n = CONVERT(DECIMAL(18,6),LEFT(@Ov, LEN(@Ov) - 2))
--判断截除最后两位数之后,使用ISNUMERIC判断是否为有效的数值,如果不是返回NULL
IF (ISNUMERIC(@n) = 0)
RETURN NULL
--下面做单位转算,如果遇上有新单位时,可以作相应添加
IF (@Ov LIKE '%TB')
SET @v = @n * 1024 * 1024 * 1024
IF (@Ov LIKE '%GB')
SET @v = @n * 1024 * 1024
IF (@Ov LIKE '%MB')
SET @v = @n * 1024
IF (@Ov LIKE '%KB')
SET @v = @n
RETURN @v
END
下面为了应用这个函数,例举例子:
复制代码 代码如下:
CREATE TABLE test(id int identity(1,1),size NVARCHAR(50))
GO
INSERT INTO [test] values('23.5mb'),('10gb'),('12.7mb'),('8GB')
go
SELECT [id],[size] FROM test ORDER BY [dbo].[udf_OrderLimitSize]([size])
执行结果:
相关文章
通过创建SQLServer 2005到 Oracle10g 的链接服务器实现异构数据库数据转换方案
通过创建SQL Server 2005到 Oracle10g 的链接服务器实现异构数据库数据转换方案,需要的朋友可以参考下。2011-06-06
Windows2003 SQL2005添加系统用户修改系统登录密码
这篇文章主要介绍了Windows2003 SQL2005添加系统用户修改系统登录密码的方法,大家如何忘记了系统的密码可以试试这个方法2013-11-11
Access 导入到SQL Server 2005的方法小结
这篇文章主要介绍了Access 导入到SQL Server 2005的方法小结,需要的朋友可以参考下2014-09-09
SqlServer 2005 T-SQL Query 学习笔记(4)
作者他很喜欢建立数字辅助表(即是1-N的数字按顺序组成的表),关于如何建立这些辅助表,然后他给了一些例子,这些例子很有代表性。2010-02-02
sqlserver 2008手工修改表结构,表不能保存的问题与解决方法
今天晚上休息,写一个小程序,用的是sql server 2008,手工建立了一些表,然后我回头想到了表字段中有一些需要增加一列,回头我就插入一列,结果我保存的时候却弹出如下窗口2010-04-04


最新评论