hitdemo2002
max payne
发贴: 210
积分: 50
|
于 2002-12-18 18:18
我要向oracle81中的一个表中插入纪录, 该表由id(主键),name等字段,id为有意义的数字,就想学号一样,id由jsp页面读来的3位数字+3位流水号生成, 譬如说100001,100002,100003.......,流水号最大限制为999, 我的疑惑是:假设表中现有100001,100002......100009,100010十个连续的纪录,现在我又增加了一条,我的insert方法是在DAO中用sql语句max(id)找出最大id 100010,在他后面insert 100011这条记录,过了一会儿,我将100005这条记录删除了,等到下次我再添加纪录时,却还是用max(id)找最大的id 100011,在他后面insert 100012,可是此时100004和100006之间就出现空缺,这样下去的话,流水号达到999时就会出错了(该表实际记录数肯定在500以下),我知道原因是由我在DAO中用先找MAX(ID),然后再接着这个ID插入记录这个方法产生的,但是我不知道其他的方法, 各位大侠,用什么方法或sql语句能实现这样的: 就是当我把100005删除后,下次再添加纪录时,不是在100011后面插入,而是自动找到100004和1000006之间的空缺,发现数字不连续,将纪录插为100005,这样就可以避免流水号浪费。 不知道我表述明白了吗? 请帮忙,多谢多谢。
why edited on 2003-06-22 01:14
|