将表中的数据保留一周的数据其余全部转移
用于数据库迁移。
code:
USE Kyt
GO
/* Daily_StockSettlement 保留最近一周数据,其他全部迁移至历史数据库表(KYT_History.dbo.Daily_StockSettlement_his) */
-- 此过程适合sqlserv 2005 或2005以上的版本
-- SELECT TOP 100 DSS_CreateDate FROM Daily_StockSettlement ORDER BY DSS_CreateDate ASC
-- SELECT TOP 100 DSS_CreateDate FROM KYT_History.dbo.Daily_StockSettlement_his ORDER BY DSS_CreateDate ASC
-- SELECT count(1) FROM Daily_StockSettlement
DECLARE @mindate DATETIME,@maxdate DATETIME,@maxday INT,@maxpage INT,@minday INT
SET @maxday = 1 --每次操作【*】天的数据 如1天,当每天的数量太大时,建议减小此值(现在数据中一天约20000条数据)
SET @minday = 9 --保留最近 【*】 天的数据 如 9天
--获取当前表数据的最前一条(order by 创建时间)
SELECT TOP 1 @mindate = DSS_CreateDate FROM Daily_StockSettlement ORDER BY DSS_CreateDate ASC
--获取当前表数据的最后一条(order by 创建时间)
SELECT TOP 1 @maxdate = DSS_CreateDate FROM Daily_StockSettlement ORDER BY DSS_CreateDate DESC
--设置循环的次数
SET @maxpage = ((DATEDIFF(DAY,@mindate,@maxdate))-@minday)/@maxday
PRINT '共需要执行 '+ convert(varchar(10), @maxpage)+' 次循环。'
-- 开始循环数据
WHILE (@maxpage >= 0)
BEGIN
PRINT 'NO: '+convert(varchar(10), @maxpage)+' 次循环 开始执行。。。'
---- 使用事物 将数据移动到历史表
BEGIN TRANSACTION
BEGIN TRY
IF(@maxpage > 0)
BEGIN
--最后两天的计算方式
SET @mindate = DATEADD(DAY,(@maxday),@mindate)
END
ELSE
BEGIN
--最后一天的计算方式,最后一天
SET @mindate = DATEADD(DAY,(DATEDIFF(DAY,@mindate,@maxdate))-(@minday-1),@mindate)
END
PRINT '开始将旧表的数据插入到新表中:'
INSERT INTO KYT_History.dbo.Daily_StockSettlement_his SELECT * FROM Daily_StockSettlement WHERE DSS_CreateDate < @mindate ORDER BY DSS_CreateDate ASC
PRINT '开始删除旧表中的数据:'
DELETE FROM Daily_StockSettlement WHERE DSS_CreateDate < @mindate
PRINT '正在执行 '+ convert(varchar(10), @maxpage)+' 次循环,没有发生错误,正在执行 Commit 命令。'
--提交事物
COMMIT TRANSACTION
--最后将maxpage-1
SET @maxpage = @maxpage-1
--等待20秒后继续运行此循环
WAITFOR DELAY '00:00:10';
END TRY
BEGIN CATCH
PRINT '正在执行 '+ convert(varchar(10), @maxpage)+' 次循环,并且发生错误:执行 Rollback 命令。'
PRINT '错误内容:'+ERROR_MESSAGE()
--如果发生异常 抛出错误并回滚
ROLLBACK TRANSACTION
--如果发生异常马上结束循环
BREAK
END CATCH
END --while end
GO
/*
select ERROR_LINE() as Line,
ERROR_MESSAGE() as message1,
ERROR_NUMBER() as number,
ERROR_PROCEDURE() as proc1,
ERROR_SEVERITY() as severity,
ERROR_STATE() as state1
)*/
分享到:
相关推荐
【中泰钢铁】一周重点数据一览表.pdf
用一条SQL语句将数据表中某列更新到另一个数据表里
java代码操作数据转移,把一个数据库里的东西移动到另一个数据库,自动建库建表。
1、Excel数据透视表能根据时间列和用户自定时间间隔对数据进行分组统计,如按年、季度、月、日、一周等,即你的数据源表中只需有一个日期字段就足够按照(任意)时间周期进行分组了。 2、通常,透视表项目的排列顺序...
java jsp sqlserver数据表转移到oracle实例 源代码
利用com口接收数据采集卡数据,实现实时数据保存
数据库数据转移 数据库数据转移 数据库数据转移 数据库数据转移 数据库数据转移
VB 利用INSERT语句向数据表中插入数据 VB 利用INSERT语句向数据表中插入数据
放入centos服务器中解压,可配置化进行mysql从某张表到历史表的数据迁移。该脚本可根据表中日期进行数据的定时迁移
如果要把Oracle里的大量数据(80MB以上)转移到另外的用户,另外的表空间里。可以用本文介绍的快速转移数据的方法。建新表的方式,直接插入的方。这两种方法转移数据时没有用SGA里数据缓冲区和事物处理的回滚段, 也不...
大数据量转移软件源码 大数据量转移软件&def 注意:多字段映射时 字段之间需要手动 逗号 搁开。 已尝试过数十万行数据的转移。
今天抽时间整理了一篇mysql中与天、周、月有关的时间数据的sql语句的各种写法,部分是收集资料,全部手工整理,自己学习的同时,分享给大家,并首先默认创建一个表、插入2条数据,便于部分数据的测试,其中部分名词...
表结构的创建比较简单,但是表的数据量太大,一时也想不到怎么把sqlserver表数据复制到oracle中,于是请教公司主管,用存储过程实现可以查询出所有数据的insert脚本,在oracle库中创建好表,直接把sqlserver中的...
省市区管理sql数据表设计、以及全国省市区全部最新数据,省市区管理sql数据表设计、以及全国省市区全部最新数据,省市区管理sql数据表设计、以及全国省市区全部最新数据,
51单片机在KEIL下用汇编语言,将片外RAM30-50H中数据转移至片内70-80H中。 可以从keil或protues上看到RAM的数据转移结果
简单的数据库转移
首先,逐行读取指定文件中的数据,并进行解析后保存在顺序表中。其中,文件中每行数据格式为“学号,姓名,年龄”,比如“SA10225048,[yyw1] 张三,24”。 (提示:采用顺序表结构时,顺序表中每个表元素包含三类信息...
VB中,Listview中的数据如何存入 access 的表中这个是很经典的例子,大家做软件可能用到,欢迎下载
mfc中读取编辑框数据并保存在TXT文档中