编写筛选时间的存储过程

auewho 2018-11-15 03:18:26
有两张表test和location分别代表测试信息和位置信息,现需要建立存储过程,筛选出测试信息表中所有位置不在石家庄的信息(也就是说位置在石家庄到位置变为别的地点的这段时间的测试信息过滤掉),会的请把代码写一下。
建立测试信息表:
[code=sql]create table test
(
id1 int(10) not null auto_increment,
name varchar(20),
resule varchar(10),
time datatime()
)
insert into test values('1','A','10','2018-06-17 06:22:00');
insert into test values('2','A','5','2018-06-17 06:23:02');
insert into test values('3','A','4','2018-06-17 06:24:00');
insert into test values('4','A','11','2018-06-17 06:25:00');
insert into test values('5','A','9','2018-06-17 06:26:00');
insert into test values('6','A','5','2018-06-17 06:30:00');
insert into test values('7','B','19','2018-06-17 05:22:00');
insert into test values('8','B','6','2018-06-17 05:23:00');
insert into test values('9','A','6','2018-06-17 06:20:00');
insert into test values('10','A','6','2018-06-17 06:19:00');
insert into test values('11','B','17','2018-06-17 05:25:00');
insert into test values('12','B','14','2018-06-17 05:24:00');
insert into test values('13','B','15','2018-06-17 05:26:00');
insert into test values('14','B','15','2018-06-17 05:30:00');
insert into test values('15','B','13','2018-06-17 05:31:00');
insert into test values('16','B','12','2018-06-17 05:28:00');
insert into test values('17','B','11','2018-06-17 05:27:00');
insert into test values('18','B','10','2018-06-17 05:28:04');
insert into test values('19','A','7','2018-06-17 06:21:00');
insert into test values('20','A','6','2018-06-17 06:28:00');
建立位置表
create table location
(
id2 int(10) not null auto_increment,
name varchar(20),
loc varchar(20),
time datetime()
)
insert into location values('1','A','石家庄','2018-06-17 06:23:00');
insert into location values('2','A','银川','2018-06-17 06:25:02');
insert into location values('3','A','石家庄','2018-06-17 06:29:00');
insert into location values('4','B','海口','2018-06-17' 05:13:00);
insert into location values('5','B','石家庄','2018-06-17' 05:23:04);
insert into location values('6','B','鞍山','2018-06-17' 05:26:02);


结果为:id1 name result time
5 A 9 2018-6-17 06:26:00
20 A 6 2018-6-17 06:28:00
7 B 19 2018-6-17 05:22:00
8 B 20 2018-6-17 05:23:00
14 B 15 2018-6-17 05:30:00
15 B 13 2018-6-17 05:31:00
16 B 12 2018-6-17 05:28:00
17 B 19 2018-6-17 05:27:00
18 B 10 2018-6-17 05:28:04
...全文
47 7 打赏 收藏 举报
写回复
7 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
auewho 2018-11-16
怎么样?有思路吗?
  • 打赏
  • 举报
回复
auewho 2018-11-16
位置信息表中的A insert into location values('1','A','石家庄','2018-06-17 06:23:00');
insert into location values('2','A','银川','2018-06-17 06:25:02'); 在06:23:00到6:25:02这段时间是在石家庄的,这段时间的测试信息要删除,而id1为5的时间显示为6:26:00,不应被删除
  • 打赏
  • 举报
回复
二月十六 2018-11-16
引用 4 楼 auewho 的回复:
对 关联字段是name ,id1为6的这条在结果中没有显示呀 ,在结果中已经去掉了

id1=5的,不是6,上边说错了
  • 打赏
  • 举报
回复
auewho 2018-11-16
对 关联字段是name ,id1为6的这条在结果中没有显示呀 ,在结果中已经去掉了
  • 打赏
  • 举报
回复
二月十六 2018-11-16
引用 2 楼 auewho 的回复:
就是位置信息表和测试信息表相关联,进行查询操作,只要位置信息定位显示在石家庄的这段时间的测试信息都去掉

关联字段是name吗?为啥insert into test values('6','A','5','2018-06-17 06:30:00');这条没有去掉?
  • 打赏
  • 举报
回复
auewho 2018-11-16
就是位置信息表和测试信息表相关联,进行查询操作,只要位置信息定位显示在石家庄的这段时间的测试信息都去掉
  • 打赏
  • 举报
回复
二月十六 2018-11-15
没太看明白楼主结果数据的规则
  • 打赏
  • 举报
回复
相关推荐
发帖
MySQL

5.6w+

社区成员

MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
帖子事件
创建了帖子
2018-11-15 03:18
社区公告
暂无公告