数据库字段:数据库高并发情况下重复值写入的避免 字段组合约束

10线程同时操作频繁出现插入同样数据问题虽然在插入数据时候使用了:
insert i tablename(fields....) select @t1,@t2,@t3 from tablename where not exists (select id from tablename where t1=@t1,t2=@t2,t3=@t3)
当时还是在高并发情况下无效此语句也包含在存储过程中(的前也尝试线判断有无记录再看是否写入,无效)
因此对于此类情况还是需要从数据库根本来解决就是约束否则数据库原子操作细不到我所需要层面
添加约束命令行用得人不多网上每次找SQL语句都累死还是写下来好了
需要关键就叫做 字段组合约束唯
alter table tablename add CONSTRAINT NewUniqueName Unique(t1,t2,t3)
这样可以保证 3个字段组合不重复
在生产系统数据库调整真是锱铢必较
对于数据库读操作重复暂时没有好解决思路方法就是读数据库某些条目同时将这些条目某个字段修改为1然后其他进程读时候就不会重复读取但是在多线程情况下即使我使用了SQL SERVER 2005最新特性就是类似update...output o到临时表思路方法:
update tablename _disibledevent=>output deleted.ID o @tb
where ID in
(select id from tablename where _disibledevent=>还是会造成重复读难道没有更好办法了吗?
如果大家有更好思路方法可以发出来
Tags:  数据库字段长度 数据库并发 php写入数据库 数据库字段

延伸阅读

最新评论

发表评论