-
根据多条件查询临时表想得到不同结果集的方法
当我写下如下sql语句时,我得到了输入@c参数时想得到的结果集。select*[email protected](selectidfromtbwheref=@c)但如果有@a,@b,@c,而它们分别想从@tb中得到不同的结果集,例如复制代码代码如下:if@aisnotnullbegin--得到@a想得到的endif@bisnotnullbegin--得到@b想得到的endif@cisnotnullbegin--得到@c想得到的end这样做好像没什么问题,但如果@a和@b是一起的,甚至是@a,@b,@c,@d,@e,@f等等N多种条件组合,这样就不好办了...
数据库操作教程 2022-09-23 16:53:56 -
根据日期知道当天是星期几的手动计算方法
蔡勒(Zeller)公式:w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1公式中的符号含义如下,w:星期;c:世纪-1;y:年(两位数);m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算);d:日;[]代表取整,即只要整数部分。(C是世纪数减一,y是年份后两位,M是月份,d是日数...
数据库操作教程 2022-09-23 16:51:34 -
SQLServer中实现二进制与字符类型之间的数据转换
在工控应用上,返回的数据经常会以二进制的形成存储,而这些二进制数据又是以每4个bit表示一个十六进制的数据内容。解析的时候,往往是一个字节(Byte)占用8个位(bit),高位4bit表示一个十六进制数据,低位4bit表示一个十六进制数据...
数据库操作教程 2022-09-23 16:50:09 -
sql函数实现去除字符串中的相同的字符串
复制代码代码如下:---去除字符串中重復的值函數createfunctionStringRemove(@strnvarchar(2000))returnsvarchar(2000)asbegindeclare@resultnvarchar(2000),@tempnvarchar(1000)set@result=''set@temp=''while(charindex(',',@str)<>0)beginset@temp=substring(@str,1,charindex(',',@str))if(charindex(@temp,@result)<=0)set@result=@result+@tempset@str=stuff(@str,1,charindex(',',@str),'')endreturn@resultendGO--('塗聚文','塗','塗聚文','1','23','1')--測試selectdbo.StringRemove('塗聚文,塗,塗聚文,1,23,1')...
数据库操作教程 2022-09-23 16:47:56 -
having的用法以及与where区别介绍
having的用法having子句可以让我们筛选成组后的各种数据,having子句在查询过程中慢于聚合语句(sum,min,max,avg,count).而where子句在查询过程中则快于聚合语句(sum,min,max,avg,count)。SQL实例:一、显示每个地区的总人口数和总面积.复制代码代码如下:SELECTregion,SUM(population),SUM(area)FROMbbcGROUPBYregion先以region把返回记录分成多个组,这就是GROUPBY的字面含义...
数据库操作教程 2022-09-23 16:47:44 -
判断数据库表是否存在以及修改表名的方法
一、判断数据库表是否存在:首先要拿到数据库连接conn,调用DatabaseMetaDatadbmd=conn.getDataMeta();之后调用如下方法:复制代码代码如下:/***根据表名,判断数据库表是否存在*@paramtableName*@returntrue:存在该表,false:不存在该表*/publicbooleanhasTable(StringtableName){Init();booleanresult=false;//判断某一个表是否存在try{ResultSetset=dbmd...
数据库操作教程 2022-09-23 16:46:37 -
附加到SQL2012的数据库就不能再附加到低于SQL2012的数据库版本的解决方法
昨天我只是将数据库附加到SQL2012,然后各个数据库都做了收缩事务日志的操作兼容级别这些都没有改再附加回SQL2005的时候就报错在SQL2012里附加,确实是90级别,但是在SQL2005死活附加不上备份数据库再还原也是一样重建事务日志也是一样然后我做了一个实验,检查一下附加到SQL2012的数据库和附加到SQL2005的数据库,两个数据库的文件头有什么不同注意:两个数据库的兼容级别都是90,附加到SQL2012之后我也没有动过兼容级别!!我们用同一个数据库,分别附加到SQL2005上和SQL2012上,看一下附加之后数据库的文件头有没有改变这个数据库的兼容级别是90的附加到SQL2012之后,我也不改变他的兼容级别查看文件头的SQL语句如下,实际上就是数据库的第0页:复制代码代码如下:DBCCTRACEON(3604,-1)DBCCPAGE(dlgpos,1,0,3)在SQL2012里和SQL2005里都执行一下将结果复制粘贴到一个新建的记事本里,命名好复制代码代码如下:DBCC执行完毕。如果DBCC输出了错误信息,请与系统管理员联系...
数据库操作教程 2022-09-23 16:46:24 -
把excel表格里的数据导入sql数据库的两种方法
本来最近在研究微信公众平台的,老大临时交我个任务,把excel表格里的数据导入sql数据库,我想这soeasy嘛。没想都在上面消磨了两天...把情况介绍下:在数据库中有如下这样结构的表(A表)我只取关键的及列里面还有很多数据...
数据库操作教程 2022-09-23 16:46:12 -
SqlServer备份数据库的4种方式介绍
1.用sqlserver的维护计划在这里我就不给截图演示了,这个比较简单,无非就是通过sqlserver自己的维护计划拖拽出2个一个‘备份数据库'任务和一个‘清除维护'任务。需要注意的点: 1)有备份任务里边选择备份的库尽量选‘所有用户数据库'这项,以免选择了特定数据库备份以后某天添加了新数据库却忘了勾选导致丢备份...
数据库操作教程 2022-09-23 16:45:36 -
sqlserver:查询锁住sql以及解锁方法
查看被锁表语句--查看被锁表:SELECTrequest_session_idspid,OBJECT_NAME(resource_associated_entity_id)tableNameFROMsys.dm_tran_locksWHEREresource_type='OBJECT'ORDERBYrequest_session_idASC--spid锁表进程--tableName被锁表名--根据锁表进程查询相应进程互锁的SQL语句DBCCINPUTBUFFER(249)解锁语句--解锁:DECLARE@spidINTSET@spid=52--锁表进程DECLARE@SQLVARCHAR(1000)SET@SQL='kill'+CAST(@spidASVARCHAR)EXEC(@SQL)生成解锁SQL语句--生成解锁SQLSELECTDISTINCT'DECLARE@spidINTSET@spid=',request_session_id,'DECLARE@SQLVARCHAR(1000)SET@SQL=''kill''+CAST(@spidASVARCHAR)EXEC(@SQL);'...
数据库操作教程 2022-09-23 16:43:35 -
sql存储过程实例--动态根据表数据复制一个表的数据到另一个表
动态根据表数据复制一个表的数据到另一个表把track表的记录根据mac_id后两位数字,复制到对应track_?的表中如:mac_id=12345678910,则后两位10对应表为track_10,就把此记录复制到track_10中创建一个sub_track的存储过程实现:--创建一个名为sub_track的存储过程CREATEPROCEDUREsub_track()begindeclareiint;--定义循环变量iset@imei=0;--定义imei最后两位set@t_count=0;--定义表有多少条记录变量SETi=0;SELECTCOUNT(*)INTO@t_countFROMtrack;--获取表的条数whilei<=@t_countdo--循环SELECTRIGHT(mac_id,2)INTO@imeiFROMtrackORDERBYgpstimeDESCLIMITi,1;--获取imei最后两位set@imei=CONVERT(@imei,SIGNED);--转为数字--SQL语句set@sql1="(mac_id,mac_type,channel,type,x...
数据库操作教程 2022-09-23 16:43:15 -
SQL语句中不同的连接JOIN及join的用法
为了从两个表中获取数据,我们有时会用JOIN将两个表连接起来。通常有以下几种连接方式:JOIN or INNERJOIN(内连接):这两个是相同的,要求两边表同时有对应的数据,返回行,任何一边缺失数据就不显示...
数据库操作教程 2022-09-23 16:42:45