时间:2021-05-23
前言
相信大家都有所体会,无论何种语言,一旦看见代码中有重复性的代码则想到封装来复用,在SQL同样如此,若我们没有界面来维护而且需要经常进行的操作,我们会写脚本避免下次又得重新写一遍,但是这其中就涉及到一个问题,这个问题我开始也没太在意,直到某时某刻,老大看到我写的脚本后笑着问了一句,你的脚本可否重复执行,我懵逼了,很显然不能,如果不能避免这种情况发生,比如进行插入操作,当下次其他同事来执行其脚本时可能会插入重复数据,如果是在线上那就傻逼了,所以老大又给我上了一课,从此之后每次写脚本都加逻辑判断,是的,也就是可重复执行。
接下来讲讲最近项目中遇到的场景。
话题引入
在国民成年人体质测试中需要计算成年年纪且体侧年龄为20-59岁,若当前日期未超过成年人出生日期则岁数减一,否则不减,例如一个成年人出生日期为1991-11-01,此时该成年人的体侧年龄为25岁,若为1991-10-01则体侧年龄为26岁,此为第一步。第二步则是分组,每个年龄阶段的人测试的项目不一样,即需要根据年龄进行分组,在体侧文档中分为3组,一组为男性20-39岁,一组为女性20-39,最后一组不分男女为40-59。最后我们需要做的是根据不同的年龄阶段和性别进行分组。
我们建立如下表。
由上我们可以看出有20-39岁的男性,也有20-39岁的女性。也有40-59岁的男性等,关键在于我们怎么利用SQL根据国民成年人体质测试文档计算出上述成年人的实际年龄呢。
SELECT Id , DATEDIFF(YEAR, Birthday, GETDATE()) AS age , NameFROM dbo.t1看到上述查询明显不正确,未到出生日期的人年龄并未减掉1,此时我们可以利用DATEPART函数,第一个参数指定为dayofyear,此参数表明指定日期到在这一年的天数,例如我们想要获取当前已经过了多少天。
SELECT DATEPART(dayofyear, GETDATE())SELECT DATEPART(dayofyear, '2017-12-31')我们通过出生日期的天数和当前日期的天数,若大于当前日期天数则说明生日还未到,否则减掉1。
SELECT Id , DATEDIFF(YEAR, Birthday, GETDATE()) - CASE WHEN DATEPART(DAYOFYEAR, Birthday) > DATEPART(DAYOFYEAR, GETDATE()) THEN 1 ELSE 0 END Age , NameFROM dbo.t1此时我们完成了年龄阶段的区分,下面我们再插入到另外一个数据库它test2中。 这里我能想到的是两种种方式,若还有其他欢迎补充。
LEFT JOIN ....IS NULL
我们利用左连接来进行插入,同时若重复的话则另外需要插入的表主键必定不为NULL,所以我们外加NULL判断则可以去除重复插入问题。
INSERT INTO test2.dbo.t2 ( UserId , Birthday , Gender , Name ) SELECT t1.Id , t1.Birthday , t1.Gender , t1.Name FROM dbo.t1 AS t1 LEFT JOIN test2.dbo.t2 AS t2 ON t1.Id = t2.UserId WHERE t2.Id IS NULL当再次执行时则返回受影响行数为0
NOT EXISTS/NOT IN
INSERT INTO test2.dbo.t2 ( UserId , Birthday , Gender , Name ) SELECT t1.Id , t1.Birthday , t1.Gender , t1.Name FROM dbo.t1 AS t1 WHERE NOT EXISTS(SELECT t2.UserId FROM test2.dbo.t2 t2 WHERE t2.UserId = t1.Id)总结
本节我们讲述了利用写SQL脚本避免重复插入问题,同时来讲述了如何根据出生日期查询实际年龄。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
之前有群友反应同事给了他一个几百MB的sql脚本,导入数据库再从数据库读取数据有点慢,想了解下有没有可以直接读取sql脚本到pandas的方法。解析sql脚本文
怎么把这个数据库另存为出来,出来以后,我移植到了其他机器,怎么导入? 三种方法:1)导出成sql脚本到其他电脑上重新运行建表等操作;2)将数据库备份后把备
本文实例讲述了C#创建数据库及导入sql脚本的方法。分享给大家供大家参考,具体如下:C#创建数据库://////创建数据库//////连接字符串///数据库名称
PowerDesigner连接数据库的实例详解PowerDesigner连接数据库大致如下列图所示:选择需要连接的数据库类型:有两个选择,一、导入Sql脚本文件
PHP快速导入大量数据到数据库的方法第一种方法:使用insertinto插入,代码如下:$params=array(‘value'=>'50′);set_tim