sql是不是在3个工作日内
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql是不是在3个工作日内相关的知识,希望对你有一定的参考价值。
参考技术A 在SQLServer中出于数据安全的考虑,所以需要定期的备份数据库。而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求管理员
每天守到晚上1点去备份数据库。要实现数据库的定时自动备份,最常用的方式就是使用SQLServer代理中的作业。启动SQLServer
Agent服务,然后在其中新建作业,作业中添加1个备份步骤,类型是T-SQL脚本,然后在命令中输入如下SQL语句,该语句实现了对数据库
TestDB1的完整备份,备份文件在C盘Backup文件夹中,文件名就是TestDB1+当时备份的日期字符串.bak。
declare@namevarchar(250)
set@name='C:BackupTestDB1_'+
convert(varchar(50),getdate(),112)+'.bak'
BACKUPDATABASE[TestDB1]TO
DISK=@name
WITHNOFORMAT,NOINIT,
NAME=N'TestDB1-完整数据库备份',
SKIP,NOREWIND,NOUNLOAD
创建好步骤以后,接下来就是创建计划,创建计划的操作十分简单,界面上说明的很详细了,我就不多说了。另外还可以配置警报和通知,不过一般很少用这个。
使用SQL作业中执行SQL脚本进行备份的方法虽然已经很简单了,但是至少还是要去写BACKUP脚本,这点有些人觉得不爽,那有没有更简单,更懒的方法来实现数据库的自动定时备份呢?有,那就是“维护计划”。
“维护计划”是在SSMS的对象资源管理中“管理”节点下面。使用维护计划可以通过可视化的操作,只点点鼠标就可以创建数据库维护的SSIS包,然
后仍然是通过SQLServer作业的方式来运行。维护计划与前面说到的备份方法本质的不同就是:维护计划是SSIS包,上面的是T-SQL脚本。
假设我们现在有一个生产系统的数据库需要进行备份,由于数据库中的数据很多,数据文件很大,如果每次都进行完整备份那么硬盘占用了很大空间,而且备
份时间很长,维护起来也很麻烦。对此我们可以采用完整备份+差异备份的方式,每周日进行一次完整备份,每天晚上进行一次差异备份。使用差异备份可以减小备
份文件的大小,同时还可以提高备份的速度,不过缺点就是必须使用上一次完整备份的文件和差异备份的文件才能还原差异备份时刻的数据库,单独只有差异备份文
件是没有意义。
下面我来讲一下如何通过维护计划来实现完整备份+差异备份:
(1)在SSMS的对象资源管理器中右击“维护计划”,选择“维护计划向导”,系统将弹出向导窗口,如图:
这里向导已经告诉我们维护计划到底能够干什么了,其中最后一项“执行数据库备份”正是我们所需要的。
(2)点击“下一步”按钮,进入选择计划属性窗口,输入计划的名称,由于我们的计划包括2部分:完整备份和差异备份,这2部分的执行计划是不一样的,一个是一周执行一次,另一个是一天执行一次,所以要选择“每项任务单独计划”,如图:
(3)单击“下一步”按钮,选择维护任务,这里就是可以在维护计划中执行的任务,如果你想执行的任务在这里没有,那就还是不用维护计划来做,自己写SSIS包或者SQL语句吧。我们要执行的任务都在这里,选中这2个任务,如图:
(4)单击“下一步”进入选择维护任务顺序的界面,这里我们可以看到选中的任务出现在列表中,但是我们并不能调整其顺序,那是因为在步骤2中我们选
择的是每项任务单独计划,所以这2个任务是独立的,没有先后顺序可言。如果当时选择的是另一个选项,那么这里就可以调整顺序了。
(5)选中“备份数据库(完整)”然后单击“下一步”按钮,系统将转到定义完整备份任务的界面,如图:
这个界面实在太长了,我把任务栏隐藏了都显示不完,出现了滚动条,这里我们选择要进行备份的数据库,选择为每个数据库创建备份文件,文件保存在C盘
Backup目录下,扩展名是bak,出于安全起见,我们可以选中“验证备份完整性”,当然也可以不选。在SQL2008中提供了压缩备份的新特性,使得
备份文件更小,备份速度更快,这里我们就是由压缩备份。最后是选择执行计划,我这里选的是每周日晚上0点的时候执行。
(6)单击“下一步”按钮,进入差异备份任务的设置界面,和上一步的界面是一样的,操作也是一样的,计划这里我们可以选择除了周日以外的每天进行差异备份,如图:
(7)单击“下一步”按钮,进入选择报告选项,这里我们可以将这个维护计划的执行报告写入文本文件中,也可以讲报告通过电子邮件发送给管理员。如果
要发送邮件的话,那么需要配置SQLServer的数据库邮件,另外还要设置SQL
Server代理中的操作员,关于邮件通知操作员的配置网上也讲的比较多,我这里就不详述了。
(8)单击“下一步”按钮,进入“完成该向导”的界面,系统列出了向导要完成的工作,如图:
(9)单击“完成”按钮,向导将创建对应的SSIS包和SQL作业:
(10)完成后,我们再刷新下对象资源管理器,我们可以看到对应的维护计划和该计划对应的作业:
现在维护计划是创建好了,急着想看看执行后的效果如何,不需要等到晚上12点去了,在“作业”下面,右击
DbBackupPlan.Subplan_1,选择“作业开始步骤”系统便立即执行该作业,系统运行完成后,我们便可在C:Backup文件夹下面有
我们做的完整备份的备份文件。
以上的操作可以是纯粹的无键盘操作,不用写任何脚本,只需要点点鼠标即可。
这里需要注意的是,我们如果不是周日制定的该维护计划,那么制定该维护计划前一定要做个完整备份,而且该备份至少要保留到下周,不然到时候出了问题,发现只有这几个工作日的差异备份,而上一次的完整备份又被删了,那就郁闷了。
除了使用维护计划向导以外,我们还可以直接新建维护计划,也可以修改意见创建的维护计划。我们就以修改维护计划为例。对于前面创建好的完整备份+
差异备份维护计划,现在我们需要每周对数据库备份进行一次清理,在完整备份完成后,要将1个月前的备份删除掉。那么我们只需要修改一下维护计划即可,具体
操作如下:
(1)右击我们的维护计划,在弹出式菜单中选择“修改”选项,系统将新建一个选项卡来显示当前的维护计划。如图:
左下角是可用的维护计划组件,右下面板是维护计划的流程设置面板,其上面就是该计划的子计划列表。
(2)选中Subplan_1子计划,也就是每周完整备份的子计划,将“清除历史记录”任务从工具箱中拖拽到计划面板中,然后在面板中单击“备份数据库(完整)”组件,系统将显示一个绿色的箭头,将绿色箭头拖拽到“清除历史记录”组件上,如图:
也就是说在成功完整备份了数据库后,接下来才执行清除历史记录任务。
(3)右击“清除历史记录”任务,在弹出式菜单中选择“编辑”选项,系统将弹出清除历史记录任务设置窗口,如图:
这里既可以清除历史记录日志,也可以删除硬盘上的历史数据。这里我们要删除4周前的历史备份数据,单击“确定”回到计划面板,我们可以看到原本“清
除历史记录”任务上的小红叉不见了。单击“保存”按钮,该计划便保存起来。(说明:我在SQL2008中文版虚拟机里面做的时候一旦修改维护计划,保存的
时候就报错灾难性故障,不过我本机的英文版是正常的,不知道是我虚拟机的问题还是中文版的Bug,反正在英文版里面是对的。)
这样修改后,以后我们都不用手动去删除那些很久以前的数据库备份了,系统在执行完备份后就会删除那些满足条件的备份数据。
如何查找两个不同日期字段SQL在一定时间间隔内是不是匹配?
【中文标题】如何查找两个不同日期字段SQL在一定时间间隔内是不是匹配?【英文标题】:How to find if there is a match in a certain time interval between two different date fields SQL?如何查找两个不同日期字段SQL在一定时间间隔内是否匹配? 【发布时间】:2020-01-09 10:12:53 【问题描述】:我的事实表中有一个列,它根据以下案例陈述定义供应商是旧的还是新的:
CASE
WHEN (SUBSTRING([Reg date], 1, 6) = SUBSTRING([Invoice date], 1, 6)
THEN ('New supplier')
ELSE('Old supplier')
END as [Old/New supplier]
因此,例如,如果供应商在 201910 年注册并且发票日期为 201910 年,那么该供应商将被视为该月的“新供应商”。现在我想通过对供应商编号进行不同的计数来计算每个月的旧/新供应商的数量,这不是问题。最后一步很棘手,现在我想计算 12 个月内新/旧供应商的数量(如果在任何滞后的 12 个月内发票日期和注册日期匹配)。所以我创建了以下 mdx 表达式:
aggregate(parallelperiod([D Time].[Year-Month-Day].[Year],1,[D Time].[Year-Month-Day].currentmember).lead(1) : [D Time].[Year-Month-Day].currentmember ,[Measures].[Supplier No Distinct Count])
我面临的问题是它会将供应商编号“1234”计算两次,因为在此期间它既是新的又是旧的。我希望的是,如果它找到一个匹配项,它将被视为该 12 个月期间的“新”供应商。
这就是结果的最终结果,但我希望它对于“旧”而言为零,因为注册日期和发票日期在该 12 个月期间匹配一次,对于 201910 的整个滚动 12 个月,它应该被视为新日期
我们非常感谢任何帮助、可能的方法或想法。
最好的问候, 红宝石
【问题讨论】:
你只想要 mdx 还是 sql 也可以?此外,您的 12 个月期间是如何定义的。我的意思是你得到类似 2 个变量 201811 和 201912 的东西吗? 感谢您的回复!任何一个都可以,我只是想找到一个可能的解决方案:) 【参考方案1】:首先在供应商级别聚合,然后在类型级别聚合:
select type, count(*)
from (select supplierid,
(case when min(substring(regdate, 1, 6)) = min(substring(invoicedate, 1, 6))
then 'new' else 'old'
end) as type
from t
group by supplierid
) s
group by type;
注意:我假设您的日期列采用某种晦涩的字符串格式,以便您的代码正常工作。否则,您应该使用适当的日期函数。
【讨论】:
【参考方案2】:SELECT COUNT(*) OVER () AS TotalCount
FROM Facts
WHERE Regdate BETWEEN(olddate, newdate) OR InvoiceDate BETWEEN(olddate, newdate)
GROUP BY
Supplier
上述查询将返回该时间段内的所有供应商,然后将它们分组。因此 COUNT(*) 将只包括唯一订阅者。
您可能想要更改 WHERE 子句,因为我不太明白您是如何获得 12 个月期限的。通常,如果您的 where 子句在该时间段内返回供应商(它们不必是唯一的),那么 group by 和 count 将处理其余部分。
【讨论】:
mdx 的原因是获得滚动 12 个月,即 201910 将是 (201811-201910) 和 201909 将是 (201810-201909) 等等。所以如果供应商在任何相关期间都是新的该时间段内的几个月,它不仅在匹配的那个月内,而且在整个期间都算作新的。以上是关于sql是不是在3个工作日内的主要内容,如果未能解决你的问题,请参考以下文章
微信支付提示:支付失败,如果已经扣款,资金会在0~3个工作日内原路退回
内推面试成功概率大吗?10年招聘HR告诉你关于内推的3个真相