-
基于SQLServer中如何比较两个表的各组数据图解说明
开始前一阵子,在项目中碰到这样一个SQL查询需求,有两个相同结构的表(table_left&table_right),如下:图1.检查表table_left的各组(groupId),是否在表table_right中存在有一组(groupId)数据(data)与它的数据(data)完全相等.如图1.可以看出表table_left和table_right存在两组数据完整相等:图2.分析从上面的两个表,可以知道它们存放的是一组一组的数据;那么,接下来我借助数学集合的列举法和运算进行分析。先通过集合的列举法描述两个表的各组数据:图3.这里只有两种情况,相等和不相等...
数据库操作教程 2022-09-23 17:16:46 -
Replace关键字的妙用查询是否包含某个特定字符串
在sqlserver中Replace关键字主要是用来将字符串中的某个字符替换成别的字符,今天要逆向思维,它还可以用来查询是否包含某个特定字符串,例如给定下面数据集 期望从这个数据集中获取包含“aaa”字符的记录,注意第2条数据不是包含“aaa”,而是包含“aaaa”。期望的”“结果如下: 传统的思维肯定是想如何查出包含有3个a的字符串,有的人会像用like,但这样会连同4个a也查出来...
数据库操作教程 2022-09-23 17:15:12 -
sql不常用函数总结以及事务,增加,删除触发器
sql不常用函数总结以及事务,增加,删除触发器distinct删除重复行declare@x申明一个变量convert(varchar(20),tscore.tenglish)类型转换cast(xxasvarchar(10))类型转换www...
数据库操作教程 2022-09-23 17:08:54 -
SqlServer:多行合并成一行,并做分组统计的两个方法
复制代码代码如下:--创建test表,插入数据CREATETABLEtest(codevarchar(50),[values]varchar(10),[count]int)INSERTtestSELECT'001','aa',1UNIONALLSELECT'001','bb',2UNIONALLSELECT'002','aaa',4UNIONALLSELECT'002','bbb',5UNIONALLSELECT'002','ccc',3; --方法一--将多行合并成一行,并做分组统计SELECTcode, [values]= stuff(b.[values]...
数据库操作教程 2022-09-23 17:08:19 -
SQLServer日期函数CAST和CONVERT以及在业务中的使用介绍
最近时间刚从客户端转入后台写服务,对于后台数据库以及服务的书写完全是个小白,所以最近写的肯定没有太多技术含量。首先把遇到的问题摆出来:还是那张错误上报表,字段主要有上报错误ID(ErrorID),上报人(ReportPerson),上报时间(ReportTime)精确到毫秒,现在要做的统计是:(1)统计一定时间内【起止时间精确到毫秒】(beginTime,endTime)每个人每天上报的错误个数(2)统计一定时间内【起止时间到精确到月】(beginTime,endTime)按月统计每个人上报的错误总数...
数据库操作教程 2022-09-23 17:06:21 -
获取数据库中两个时间字段的相差天数及ABS/DATEDIFF函数应用
复制代码代码如下:SELECTABS(DATEDIFF(dd,EndDate,BeginDate))FROMdbo.WorkingPlan其中,WorkingPlan为一张表,EndDate和BeginDate为WorkingPlan表中的结束时间和开始时间如果哪里有不正确的地方,欢迎批评指正,共同进步。...
数据库操作教程 2022-09-23 17:06:11 -
SQLServer误区30日谈第18天有关FileStream的存储,垃圾回收以及其它
误区#18:如下多个有关FileStream的误区全部错误18a)FileStream数据可以在远程存储 不能,由于FileStream数据容器(指的是存放FileStream文件的NTFS文件夹,杜撰出来的术语)必须像数据文件或日志文件那样符合本地存储策略-也就是说,这个数据容器必须放在对于运行SQLServer的WindowsServer是本地存储(译者注:也就是在‘计算机'里能看到的存储,DAC当然是了,其实SAN这类不直接连接服务器的也算是)访问FileStream数据只要客户端连接到了SQLServer服务器并获取响应的事务上下文后,就可以通过UNC路径进行访问了。18b)FileStream的数据容器可以嵌套 不能,对于同一个数据库的两个不同的FileStream容器可能在同一个目录下,但是却不能嵌套...
数据库操作教程 2022-09-23 16:59:41 -
同一个sql语句连接两个数据库服务器
execsp_addlinkedserver'逻辑名称','','SQLOLEDB','远程服务器名或ip地址'execsp_addlinkedsrvlogin'逻辑名称','false',null,'用户名','密码'go建立完成之后就可以正常使用了select*from逻辑名称。数据库名称...
数据库操作教程 2022-09-23 16:57:50 -
SQLServer中求两个字符串的交集
使用javascript的数组来计算,代码如下:复制代码代码如下:usetempdbgoif(object_id('fn_getArray')isnotnull)dropfunctiondbo.fn_getArraygocreatefunctionfn_getArray(@inStr1varchar(8000),@inStr2varchar(8000))returnsvarchar(8000)asbegindeclare@strvarchar(8000)set@str='vara=['''+replace(@inStr1,',',''',''')+'''];varb=['''+replace(@inStr2,',',''',''')+'''];varc=""for(vari=0;i<a...
数据库操作教程 2022-09-23 16:56:51 -
MSSQL计算两个日期相差的工作天数的语句
复制代码代码如下:ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo]...
数据库操作教程 2022-09-23 16:56:19 -
目前用到的两个分页存储过程代码
第一个,取得数据总行数复制代码代码如下:setANSI_NULLSONsetQUOTED_IDENTIFIERONgoALTERPROCEDURE[sq8reyoung].[fenye_num](@TableNamesNVARCHAR(200),@Filternvarchar(200))ASIF@Filter=''SET@Filter='WHERE1=1'ELSESET@Filter='WHERE'+@FilterEXECUTE('selectcount(*)from'+@TableNames+''+@Filter)第二个取得分页数据复制代码代码如下:setANSI_NULLSONsetQUOTED_IDENTIFIERONgoALTERPROCEDURE[sq8reyoung]...
数据库操作教程 2022-09-23 16:56:01 -
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