数据库“自定义存储过程”超级难题,编写复杂计算
有一个表 table, 它只有一个字段,也是主键:
uid bigint
uid是一特殊类型的数据,它的取值只能为1,2,4,6,8……且不可重复(因此最多只能有64条记录)。
对该表进行 INSERT 时,由于uid是不可重复,又不能自动增长,我们必须指定它的值。但问题是如何确定uid值?
如果表中已经有(1,2,4),则uid可取8;
如果表中已经有(1,4),则uid可取2; // 为了利用有限的储存空间
方法1:在程序中实现的,检索所有的uid,并确定可用的数值。但是,由于它是主键,必须保证插入时没有重复!锁定表?还是利用编程同步?由于实际的运行中是分布式的计算,编程同步无效,只能是锁定表。(可惜我不知道怎么做)
方法2:编写储存过程,,但我不知道具体的算法。。
=================================================
高分征求解决方案!