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

时间:2024-01-21 00:13:31 

10线程同时操作,频繁出现插入同样数据的问题。虽然在插入数据的时候使用了:
insert inti 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)
这样可以保证三个字段组合不重复
在生产系统数据库的调整真是锱铢必较。。。。。。
对于数据库读操作的重复暂时没有好的解决方法,就是读数据库某些条目同时将这些条目某个字段修改为1,然后其他进程读的时候就不会重复读取。但是在多线程情况下即使我使用了SQL SERVER 2005最新的特性,就是类似update...output into到临时表的方法:

update tablename set OnCheck=1,LastLockTime=getdate(),LastChecktime=getdate()
output deleted.ID into @newtb
where ID in
(select id from tablename where Oncheck=0)
还是会造成重复读。难道没有更好的办法了吗?

如果大家有更好的方法,可以发出来。

标签:数据库,高并发,重复值
0
投稿

猜你喜欢

  • web脚本程序攻击的防范

    2007-10-18 13:29:00
  • js自定义弹框插件的封装

    2024-05-28 15:38:36
  • 新 API 寻求让 JavaScript 操作本地文件

    2009-11-27 18:28:00
  • Python如何实现自动发送邮件

    2022-05-09 04:22:55
  • nodejs简单实现TCP服务器端和客户端的聊天功能示例

    2024-05-03 15:55:56
  • img标签中alt和title属性的正确使用

    2008-01-10 12:59:00
  • Python中使用Tkinter模块创建GUI程序实例

    2023-01-22 09:37:38
  • python 爬取古诗文存入mysql数据库的方法

    2024-01-28 13:35:26
  • python绘制神器五角星+小黄人+樱花

    2022-02-11 03:45:27
  • python脚本调用iftop 统计业务应用流量的思路详解

    2022-02-07 02:37:12
  • python内存管理机制原理详解

    2021-05-24 16:19:48
  • MySQL数据库中对前端和后台进行系统优化

    2009-01-04 13:39:00
  • 使用Python解决常见格式图像读取nii,dicom,mhd

    2021-11-14 23:36:59
  • 如何实现文件上传并自动归类功能?

    2010-05-24 18:37:00
  • python集合的新增元素方法整理

    2022-10-13 02:45:28
  • pandas进行数据的交集与并集方式的数据合并方法

    2022-05-16 08:48:08
  • 网易首页的新闻代码

    2022-02-24 16:01:15
  • Pytest fixture及conftest相关详解

    2021-06-23 11:37:31
  • SQL Select语句完整的执行顺序

    2008-09-28 21:22:00
  • Facebook开源一站式服务python时序利器Kats详解

    2023-11-13 18:29:13
  • asp之家 网络编程 m.aspxhome.com