关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?

时间:2021-11-12 01:52:36
数据库,数据库是MySQL数据库里面有这样一组数据
seq    begindate     begintime     enddate    endtime
1         2014-8-1       16:9          2014-8-1      18:11
2       2014-8-2         15:0          2014-8-2     15:11

怎么样编程实现这样时间的拆分?

seq      date            begintime       endtime
1         2014-8-1       16:9          2014-8-1      16:59
1         2014-8-1       17:0          2014-8-1      17:59
1         2014-8-1       18:0          2014-8-1      18:11
2          2014-8-2         15:0          2014-8-2     15:11

14 个解决方案

#1


引用 楼主 u010735215 的回复:



DELIMITER //
create procedure test(in pi_begin_time datetime,in pi_end_time datetime)
begin
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);

set l_start_dt = pi_begin_time;
loop_label: LOOP

set l_str = concat(date_format(l_start_dt,'%Y-%m-%d %H'),':','59');
set l_end_dt = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt>=pi_end_time then
select l_start_dt,pi_end_time;
leave loop_label;
end if;
select l_start_dt,l_end_dt;
set l_start_dt = DATE_ADD(l_end_dt,INTERVAL 1 MINUTE);
END LOOP;
END;
//


#2


引用 1 楼 zlloct 的回复:
Quote: 引用 楼主 u010735215 的回复:



DELIMITER //
create procedure test(in pi_begin_time datetime,in pi_end_time datetime)
begin
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);

set l_start_dt = pi_begin_time;
loop_label: LOOP

set l_str = concat(date_format(l_start_dt,'%Y-%m-%d %H'),':','59');
set l_end_dt = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt>=pi_end_time then
select l_start_dt,pi_end_time;
leave loop_label;
end if;
select l_start_dt,l_end_dt;
set l_start_dt = DATE_ADD(l_end_dt,INTERVAL 1 MINUTE);
END LOOP;
END;
//




具体怎么执行呢??

#3


引用 2 楼 u010735215 的回复:

假设表名为test;


DELIMITER $$
create procedure test()
BEGIN
DECLARE l_start_dt1 datetime;
DECLARE l_end_dt1 datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);
DECLARE l_seq int;
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE done INT DEFAULT FALSE;
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
OPEN C1;
l_loop: LOOP
FETCH C1 into l_seq,l_start_dt,l_end_dt;


IF done THEN
  LEAVE l_loop;
END IF;
set l_start_dt1 = l_start_dt;

loop_label: LOOP 
set l_str = concat(date_format(l_start_dt1,'%Y-%m-%d %H'),':','59');
set l_end_dt1 = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt1>=l_end_dt then
select l_seq,l_start_dt1,l_end_dt;
leave loop_label;
else
select l_seq,l_start_dt1,l_end_dt1;
end if;
set l_start_dt1 = DATE_ADD(l_end_dt1,INTERVAL 1 MINUTE);
END LOOP loop_label;
END LOOP l_loop;
CLOSE C1;
END$$

 DELIMITER ;
--调用
call test();

#4


都是高手啊,膜拜

#5


是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

#6


是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

#7



是不是直接在MySQL运行就可以了?不好意思,我没有学过存储过程。
使用起来还是迷糊……



引用 3 楼 zlloct 的回复:
Quote: 引用 2 楼 u010735215 的回复:

假设表名为test;


DELIMITER $$
create procedure test()
BEGIN
DECLARE l_start_dt1 datetime;
DECLARE l_end_dt1 datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);
DECLARE l_seq int;
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE done INT DEFAULT FALSE;
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
OPEN C1;
l_loop: LOOP
FETCH C1 into l_seq,l_start_dt,l_end_dt;


IF done THEN
  LEAVE l_loop;
END IF;
set l_start_dt1 = l_start_dt;

loop_label: LOOP 
set l_str = concat(date_format(l_start_dt1,'%Y-%m-%d %H'),':','59');
set l_end_dt1 = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt1>=l_end_dt then
select l_seq,l_start_dt1,l_end_dt;
leave loop_label;
else
select l_seq,l_start_dt1,l_end_dt1;
end if;
set l_start_dt1 = DATE_ADD(l_end_dt1,INTERVAL 1 MINUTE);
END LOOP loop_label;
END LOOP l_loop;
CLOSE C1;
END$$

 DELIMITER ;
--调用
call test();

#8


引用 6 楼 u010735215 的回复:
是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();

#9


引用 8 楼 zlloct 的回复:
Quote: 引用 6 楼 u010735215 的回复:

是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();


运行的时候出现这样的情况??
关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?

#10


只能写存储过程拆分了。

#11


引用 9 楼 u010735215 的回复:
Quote: 引用 8 楼 zlloct 的回复:

Quote: 引用 6 楼 u010735215 的回复:

是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();


运行的时候出现这样的情况??
关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?


看看 test表的SEQ列存在不?下面的定义游标的sql用到了SEQ列,
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;

#12


引用 10 楼 mchdba 的回复:
只能写存储过程拆分了。


刚才修改了一下 运行结果不对啊 

#13



的确应该修改一下下 没有学过这个 刚读懂一些些
引用 11 楼 mchdba 的回复:
Quote: 引用 9 楼 u010735215 的回复:

Quote: 引用 8 楼 zlloct 的回复:

Quote: 引用 6 楼 u010735215 的回复:

是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();


运行的时候出现这样的情况??
关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?


看看 test表的SEQ列存在不?下面的定义游标的sql用到了SEQ列,
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;

#14


引用 6 楼 u010735215 的回复:
是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  



OK  貌似已经可以了 只不过好像我的数据太多了 关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现? 卡在那里了 不知道结果能不能出来  
测试三条数据已经通过了。。

#1


引用 楼主 u010735215 的回复:



DELIMITER //
create procedure test(in pi_begin_time datetime,in pi_end_time datetime)
begin
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);

set l_start_dt = pi_begin_time;
loop_label: LOOP

set l_str = concat(date_format(l_start_dt,'%Y-%m-%d %H'),':','59');
set l_end_dt = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt>=pi_end_time then
select l_start_dt,pi_end_time;
leave loop_label;
end if;
select l_start_dt,l_end_dt;
set l_start_dt = DATE_ADD(l_end_dt,INTERVAL 1 MINUTE);
END LOOP;
END;
//


#2


引用 1 楼 zlloct 的回复:
Quote: 引用 楼主 u010735215 的回复:



DELIMITER //
create procedure test(in pi_begin_time datetime,in pi_end_time datetime)
begin
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);

set l_start_dt = pi_begin_time;
loop_label: LOOP

set l_str = concat(date_format(l_start_dt,'%Y-%m-%d %H'),':','59');
set l_end_dt = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt>=pi_end_time then
select l_start_dt,pi_end_time;
leave loop_label;
end if;
select l_start_dt,l_end_dt;
set l_start_dt = DATE_ADD(l_end_dt,INTERVAL 1 MINUTE);
END LOOP;
END;
//




具体怎么执行呢??

#3


引用 2 楼 u010735215 的回复:

假设表名为test;


DELIMITER $$
create procedure test()
BEGIN
DECLARE l_start_dt1 datetime;
DECLARE l_end_dt1 datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);
DECLARE l_seq int;
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE done INT DEFAULT FALSE;
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
OPEN C1;
l_loop: LOOP
FETCH C1 into l_seq,l_start_dt,l_end_dt;


IF done THEN
  LEAVE l_loop;
END IF;
set l_start_dt1 = l_start_dt;

loop_label: LOOP 
set l_str = concat(date_format(l_start_dt1,'%Y-%m-%d %H'),':','59');
set l_end_dt1 = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt1>=l_end_dt then
select l_seq,l_start_dt1,l_end_dt;
leave loop_label;
else
select l_seq,l_start_dt1,l_end_dt1;
end if;
set l_start_dt1 = DATE_ADD(l_end_dt1,INTERVAL 1 MINUTE);
END LOOP loop_label;
END LOOP l_loop;
CLOSE C1;
END$$

 DELIMITER ;
--调用
call test();

#4


都是高手啊,膜拜

#5


是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

#6


是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

#7



是不是直接在MySQL运行就可以了?不好意思,我没有学过存储过程。
使用起来还是迷糊……



引用 3 楼 zlloct 的回复:
Quote: 引用 2 楼 u010735215 的回复:

假设表名为test;


DELIMITER $$
create procedure test()
BEGIN
DECLARE l_start_dt1 datetime;
DECLARE l_end_dt1 datetime;
DECLARE l_date datetime;
DECLARE l_str varchar(30);
DECLARE l_seq int;
DECLARE l_start_dt datetime;
DECLARE l_end_dt datetime;
DECLARE done INT DEFAULT FALSE;
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
OPEN C1;
l_loop: LOOP
FETCH C1 into l_seq,l_start_dt,l_end_dt;


IF done THEN
  LEAVE l_loop;
END IF;
set l_start_dt1 = l_start_dt;

loop_label: LOOP 
set l_str = concat(date_format(l_start_dt1,'%Y-%m-%d %H'),':','59');
set l_end_dt1 = str_to_date(l_str,'%Y-%m-%d %H:%i');
if l_end_dt1>=l_end_dt then
select l_seq,l_start_dt1,l_end_dt;
leave loop_label;
else
select l_seq,l_start_dt1,l_end_dt1;
end if;
set l_start_dt1 = DATE_ADD(l_end_dt1,INTERVAL 1 MINUTE);
END LOOP loop_label;
END LOOP l_loop;
CLOSE C1;
END$$

 DELIMITER ;
--调用
call test();

#8


引用 6 楼 u010735215 的回复:
是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();

#9


引用 8 楼 zlloct 的回复:
Quote: 引用 6 楼 u010735215 的回复:

是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();


运行的时候出现这样的情况??
关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?

#10


只能写存储过程拆分了。

#11


引用 9 楼 u010735215 的回复:
Quote: 引用 8 楼 zlloct 的回复:

Quote: 引用 6 楼 u010735215 的回复:

是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();


运行的时候出现这样的情况??
关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?


看看 test表的SEQ列存在不?下面的定义游标的sql用到了SEQ列,
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;

#12


引用 10 楼 mchdba 的回复:
只能写存储过程拆分了。


刚才修改了一下 运行结果不对啊 

#13



的确应该修改一下下 没有学过这个 刚读懂一些些
引用 11 楼 mchdba 的回复:
Quote: 引用 9 楼 u010735215 的回复:

Quote: 引用 8 楼 zlloct 的回复:

Quote: 引用 6 楼 u010735215 的回复:

是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  

对。
我都已经帮你写了:

--调用
call test();


运行的时候出现这样的情况??
关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现?


看看 test表的SEQ列存在不?下面的定义游标的sql用到了SEQ列,
DECLARE C1 CURSOR FOR SELECT SEQ,str_to_date(concat(begindate,' ',begintime),'%Y-%c-%e %k:%i') START_DT,str_to_date(concat(enddate,' ',endtime),'%Y-%c-%e %k:%i') END_DT from test;

#14


引用 6 楼 u010735215 的回复:
是不是在MySQL直接运行就可以了?不好意思,我没有学过存储过程……  



OK  貌似已经可以了 只不过好像我的数据太多了 关于数据库(MYSQL)时间段的拆分问题,怎么样编程实现? 卡在那里了 不知道结果能不能出来  
测试三条数据已经通过了。。