java如何实现定时从数据库查询新增的数据,?

主要是数据库新增的数据怎么样查询出来,定时查询所有数据我会,查询新增的数据该怎么实现呢?

有几种方法,我觉得第二种,触发器是个好主意,见下。
第一种,开个线程,定式扫描,比如每一分钟查询一次数据库,将前后数据做比对(比对方法可以在java端先把第一次的数据存到一个集合中,然后每次查询集合之后,将两次的内容在java端作比较)
第二种,在数据库端,比如oracle数据库,对这个要监控的表A建个触发器,这个表中如果有数据改变,包括楼主要的新增,修改,删除,都可以被触发,然后把改变的内容存到另一个表B中,然后java就直接从这个B表中查询就可以了,省去了比对的工作。
第三种,如果你是用的类似spring这种框架,spring自带有类似crontab的功能,可以写个一般的java类,这个类中仅仅干查询数据,比对数据的工作,然后调度的工作交给spring框架来做,基本来说这个方法与第一种相比,只是调度者不同而已
第四种,可以随便写个java类,进行查询比对,然后在跑这个java程序的主机上,比如linux主机,配置一个crontab,来定时调度。追问

第一种能详细说说么?

追答

第一种,这么说吧,就是你随便写个类,继承与thread类。
在这个类的run方法中,定义两个list,用第一个list保存你每次查询数据库中的结果集,
然后用第二个list保存之前一次的数据。
醉消耗内存的一步来了,因为要比较,你肯定需要逐个对比,看当前记录是否与之前的有重复的地方。如果不是重复的,那么肯定是新增的,如果是重复的,,,也未必就不是新增,因为有可能是以下的场景
你第一查询,查到了一条新增的记录,然后在第一和第二次查询的间隙中,这条记录被删除,然后又新增回来,这样,在一定情况下也算新增,所以这个情况的处理要根据你的业务逻辑来做处理,我不能给你个适合你的答案啦
基本思路就是这样,有问题问我哈

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2016-05-04
你想找出新增的数据,那你必须要有一个标识,用来标识是否为新增的
例如表中flag字段,默认为0,处理过之后就为1
这样,你才能判断哪条数据是新的,哪条数据是老的了

或者用时间判断来自:求助得到的回答本回答被网友采纳
第1个回答  推荐于2016-05-04
  在表上新增一个字段,比如INSERT_TIMESTAMP,要求insert数据的时候必须插入当时的时间。
  你select的时候就检查当前时间和上次查询的时间(可以在页面或者内存里记录这个上次查询的时间,或者根据你的定时策略,反推到你上次查询的时间)内的数据可以OK追问

上次查询的时间怎么保存?保存到哪里?

第2个回答  2014-09-05
多线程还是单线程?如果是多线程来处理这个问题的话要注意可能一条数据可能会被多个线程捞到,这个时候你要考虑用同步块,而识别新旧数据只需要用一个字段来标识即可追问

这个?能详细说说么 ??

第3个回答  2014-09-05
给数据加入time字段(入库时间)
查询大于你上次查询时间的数据,ok追问

上次查询的时间怎么保存?

追答

可以放到static 变量里,也可以写进txt

追问

额 感觉好深奥,还是不太懂啊

相似回答