-
SQL查询排名函数实例
在实际开发中经常会遇到计算某个字段的排名的情况如下表:totak_sales现在又如此要求:按sales的逆序排序,要求添加一个sales_rank字段,显示排名顺序方法:复制代码代码如下:SELECTa1.Name,a1.Sales,COUNT(a2.sales)Sales_RankFROMTotal_Salesa1,Total_Salesa2WHEREa1.Sales<=a2.Salesor(a1.Sales=a2.Salesanda1.Name=a2.Name)GROUPBYa1.Name,a1.SalesORDERBYa1.SalesDESC,a1.NameDESC;结果:或:复制代码代码如下:SELECTa1.Name,a1.Sales,COUNT(a2.sales)Sales_RankFROMTotal_Salesa1,Total_Salesa2WHEREa1.Sales<a2.Salesor(a1.Sales=a2.Salesanda1.Name=a2.Name)GROUPBYa1.Name,a1.SalesORDERBYa1.SalesDESC,a1.Nam...
数据库操作教程 2022-09-23 18:02:59 -
sql判断函数、存储过程是否存在的代码整理
下面为您介绍sql下用了判断各种资源是否存在的代码,需要的朋友可以参考下,希望对您学习sql的函数及数据库能够有所帮助。--库是否存在ifexists(select*frommaster..sysdatabaseswherename=N'库名')print'exists'elseprint'notexists'--判断要创建的表名是否存在ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo].[表名]')andOBJECTPROPERTY(id,N'IsUserTable')=1)--删除表droptable[dbo].[表名]GO--判断要创建临时表是否存在IfObject_Id('Tempdb.dbo.#Test')IsNotNullBeginprint'存在'EndElseBeginprint'不存在'End--判断要创建的存储过程名是否存在ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo].[存储过程名]')andOBJECTPROPERTY(id...
数据库操作教程 2022-09-23 18:00:00 -
开窗函数有浅入深详解(一)
在开窗函数出现之前存在着很多用SQL语句很难解决的问题,很多都要通过复杂的相关子查询或者存储过程来完成。为了解决这些问题,在2003年ISO SQL标准加入了开窗函数,开窗函数的使用使得这些经典的难题可以被轻松的解决...
数据库操作教程 2022-09-23 17:57:40 -
sqlserver中随机函数NewID()和Rand()
在SQLServer中,随机函数有rand(),NewID(),其中rand是在0到1内随机取数,NewID则是生成随机的uniqueidentifier唯一标识符。SELECT*FROMNorthwind..OrdersORDERBYNEWID()--随机排序SELECTTOP10*FROMNorthwind..OrdersORDERBYNEWID()--从Orders表中随机取出10条记录示例A.对变量使用NEWID函数以下示例使用NEWID()对声明为uniqueidentifier数据类型的变量赋值...
数据库操作教程 2022-09-23 17:55:30 -
利用ROW_NUMBER()OVER函数给SQL数据库中每一条记录分配行号的方法
从SQLServer2005开始,增加了一个新的函数Row_Number(),他的一个很伟大的作用就是可以在数据表中添加一列从1开始的行号,这样大大代替所有多余的代码来产生行号。下面就教大家如何使用Row_Number()函数...
数据库操作教程 2022-09-23 17:54:56 -
sqlserver四舍五入使用round函数及cast和convert函数
引言 今天和测试沟通一个百分比计算方式时遇到一个问题,我在存储过程里用到了强转CAST(32.678ASDECIMAL(5,1)) 我认为该方式只会保留一位小数,我给测试的回复是我并没有用到四舍五入函数,数据也没有四舍五入,而测试说他们自己验证后觉的数据是经过四舍五入了的。想到这里于是我再试了试存储过程的每个计算点,才发现了这个问题...
数据库操作教程 2022-09-23 17:54:55 -
SQL中位数函数实例
表还是total_sales添加一项表:SQL语句:复制代码代码如下:SELECT*from( SELECTa1.Name,a1.Sales,COUNT(a2.sales)Sales_Rank FROMTotal_Salesa1,Total_Salesa2 WHEREa1.Sales<a2.Salesor(a1.Sales=a2.Salesanda1.Name=a2.Name) GROUPBYa1.Name,a1.Sales ORDERBYa1.SalesDESC,a1.NameDESC)astabWHEREtab.sales_rank=(select(count(*)+1)div2fromtotal_sales);可以查找到中间的项,count(*)+1,这个1必须要添加,总项数假如为奇数7,则count(*)+1/2=4,假如是6则为3,都是满足的,如果不+1的话,对奇数项则不满足,如7,count(*)/2...
数据库操作教程 2022-09-23 17:48:56 -
mssqlserver中实现的unix时间戳函数(含生成和格式化,可以和mysql兼容)
直接上代码:CREATEFUNCTIONUNIX_TIMESTAMP(@ctimestampdatetime)RETURNSintegerASBEGIN/*Functionbody*/declare@returnintegerSELECT@return=DATEDIFF(SECOND,{d'1970-01-01'},@ctimestamp)return@returnENDCREATEFUNCTIONfrom_unixtime(@tsinteger)RETURNSdatetimeASBEGIN/*Functionbody*/declare@returndatetimeselect@return=DATEADD(second,@ts,{d'1970-01-01'})return@returnEND用法跟MySQL下的一样类似:selectdbo.UNIX_TIMESTAMP('2013-1-1')selectdbo...
数据库操作教程 2022-09-23 17:47:59 -
SQLServer中的RAND函数的介绍和区间随机数值函数的实现
工作中会遇到SQLServer模拟数据生成以及数值列值(如整型、日期和时间数据类型)随机填充等等任务,这些任务中都要使用到随机数。鉴于此,本文将对SQLServer中随机数的使用简单做个总结...
数据库操作教程 2022-09-23 17:45:22 -
SQL中decode()函数简介
DECODE函数,是ORACLE公司的SQL软件ORACLEPL/SQL所提供的特有函数计算方式,以其简洁的运算方式,可控的数据模型和灵活的格式转换而闻名。今天看别人的SQL时看这里面还有decode()函数,以前从来没接触到,上网查了一下,还挺好用的一个函数,写下来希望对朋友们有帮助哈!decode()函数简介:主要作用:将查询结果翻译成其他值(即以其他形式表现出来,以下举例说明);使用方法:Selectdecode(columnname,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)FromtalbenameWhere…其中columnname为要选择的table中所定义的column,·含义解释:decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)的理解如下:if(条件==值1)then return(翻译值1)elsif(条件==值2)then return(翻译值2) ......elsif(条件==值n)then return(翻译值n)else return(缺省值)endif注:其中缺省值可以是...
数据库操作教程 2022-09-23 17:45:11 -
SQLServer中merge函数用法详解
Merge关键字是一个神奇的DML关键字。它在SQLServer2008被引入,它能将Insert,Update,Delete简单的并为一句...
数据库操作教程 2022-09-23 17:44:40 -
SqlServer中REPLACE函数的使用
REPLACE用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。语法REPLACE(''string_replace1'',''string_replace2'',''string_replace3'')参数''string_replace1''待搜索的字符串表达式...
数据库操作教程 2022-09-23 17:43:50