摘要:下文讲述获取一个字符串中存在多少个网址的方法,如下实验环境:sql server 2008 R2  实现思路: 1.新建一个自定义函数,可将单个字符串拆分为含单个网址的数据表 2.采用outer apply将源数据表和函数进行相关的连接 例: ---创建字符串分解函数-将字符串转换为数据表 create Function stringChangeTable(@tmp varchar(max)) Returns @tab Table ( info ) ) As Begin set @tmp…
转自:http://www.maomao365.com/?p=6679 摘要: 下文将分享使用sql脚本输出交替变换的不同背景颜色的sql脚本的方法分享,如下所示: 实验环境:sqlserver 2008 R2 例: 下文 首先采用 over() row_number 函数生成的行编号, 然后对每行进行颜色变化操作,生成不同的背景色,如下所示: )) go ,'测试信息20180625-1') ,'测试信息20180626-2') ,'测试信息20180628-3') ,'测试信息2018062…
摘要: 下文讲述使用sql脚本,获取群组后记录的第一条数据业务场景说明: 学校教务处要求统计: 每次作业,最早提交的学生名单下文通过举例的方式,记录此次脚本编写方法,方便以后备查,如下所示: 实现思路: 使用开窗函数,对数据进行分组并按照提交时间进行排序后生成新的组内编号,如下所示: /* over开窗函数中 partition by分组 order by 排序 */ create table test(keyId int identity, keChengName ), name ), inD…
原文地址:http://www.maomao365.com/?p=7335 摘要:    数据表中,有一列是自动流水号,由于各种操作异常原因(或者插入失败),此列数据会变的不连续,下文将讲述使用sql脚本的方式获取数据表中的数据是否连续的方法分享,如下所示:    实验环境:sqlserver 2008 R2   例:获取表test中keyId是否为连续的数据 实现思路:  1.采用row_number 对表test重新生成流水号  2.采用with as (cte)表达式将重新生成流水号的表放…
摘要: 下文讲述清空数据库中所有表信息的方法分享,如下所示: 实验环境:sql server 2008 实现思路: 1.禁用所有约束,外键 2.禁用所有触发器 3.删除表数据 4.开启触发器 5.开启约束 CREATE PROCEDURE proc_deleteDateSql /* 生成清除数据库表数据的脚本方法分享 */ AS EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL' EXEC sp_MSForEachTable…
摘自:http://www.maomao365.com/?p=6612 摘要:下文介绍sql server中,sql脚本避免出现除零错误的方法分享 在各种业务系统开发中,通常会遇到除零的错误,下文分享了两种处理方法:方法1: case when end declare @a int ---分子 declare @b int ---分母 then NULL else @a/@b end as [a除以b] 方法2:nullifnullif(表达式A,表达式B)—-如果表达式A不等于表达式B,则返回…
摘要: 下文讲述使用sql脚本实现相邻两条数据相减的方法,如下所示: 实验环境:sql server 2008 R2 实现思路: 1.使用cte表达式,对当前表进行重新编号 2.使用左连接对 表达式 生成的临时表进行错位连接,并对生成的新纪录中两列进行相减 ),qty int); go ----生成基础数据 insert into [maomao365](sort, qty)values (),(), (),(), (),() go with cte_temp as ( select row_n…
摘要: 下文将分享两种将字段中null值替换为指定值的方法分享,如下所示: 实验环境:sqlserver 2008 R2 例: )) go insert into test(info)values('a'),('b'),(null),('d') go ---方法1:使用isnull替换 select keyId,isnull(info,'替换null值') as info from test go ---方法2:使用case when 替换 select keyId,case when info…
摘要: 在sqlserver开发中,常常有同事反馈无法剔除空格,我们可以通过仔细检查发现,并不是空格字符,而是tab键,如下所示: 解决方法: 对于这些特殊字符的替换,我们需采用字符所对应的ascii编码进行替换,如下所示: ) set @a ='maomao365.com@blog.com' ---替换字符串中的@字符 ),'') ---使用空格替换"@"字符 ---替换字符串中tab ),'') ---使用空格替换"tab"字符 ---替换字符串中的回车键 ),…
转自: http://www.maomao365.com/?p=4983 <span style="color:red;font-weight:bold;">下文讲述-采用sql脚本获取指定表中所有列对应的说明信息,脚本如下所示:</span> SELECT ( then d.name else '' end) [数据表名称], a.colorder [列顺序], a.name [列名称], b.name as [列类型], b.length as [列长度],…