当前位置:  数据库>sqlserver

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

    来源: 互联网  发布时间:2014-09-05

    本文导语:  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) 当时还是在高并发的情况下无效。此...

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)
还是会造成重复读。难道没有更好的办法了吗?

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

    
 
 

您可能感兴趣的文章:

  • ORACLE数据库常用字段数据类型介绍
  • RESIN做服务器,从数据库里提取字段值,页面输出顺序必须与字段顺序一致吗?
  • 在Java中,用Mircosoft SQL Server数据库,请问要进行日期字段的读取,用( ResultSet rs ; rs.getDate(1),其中1代表相应的字段为 DateTi
  • 如何将数据库表中每个字段的字段描述在JSP文件中显示出来?
  • 数据库递增字段的问题。
  • 从数据库得到多字段内容为何出错?
  • php中单个数据库字段多列显示(单字段分页、横向输出)
  • 为什么我从数据库中取记录时最多只取两个字段,多于三个字段则报错
  • oracle 实际值超过数据库某个字段指定长度报错解决
  • 请问如何取出SQL数据库里某表某字段的description内容
  • 如何在jsp中得到数据库中某张表的字段?
  • java怎样读取数据库表中字段的数据类型?
  • 急!急!数据库字段名称中有特殊符号(/,(),空格,:)在访问数据库时应该是如何处理
  • 怎样对一个数据库里的字段求和?
  • 请问jboss+oracle文件怎样配置,数据库中文字段不为乱码
  • 谁能给我一个PipedInputStream and PipedOutputStream 怎么用的例子,我想用数据库image字段对另一个imaeagezi字段
  • 如何成功读取并显示SQL数据库中image类型字段?
  • 关于jsp中取数据库中字段名的问题(急急急急急,马上解答马上给分)
  • java中的数据库结果集可以被赋值吗,可以通过结果集的方法来更新数据库字段吗?
  • !!!在Java中如何取得Resultset中的datetime和timestamp字段?数据库是SQLServer
  • sql 查询所有数据库、表名、表字段的代码
  • 请问,去会字符串型的日期,如何转化成datetime型从而写入数据库?如果不转换,能写入吗?(多谢)?
  • 请比较两种向数据库写入Blob对象的方法的优劣?
  • 如何将从JSP页面中取得的系统当前时间写入oracle数据库表中?
  • 中文问题:我的数据库中,中文写入没有问题,但中文却不能正常读出。(sqlserver2000)
  • 如何将用户注册的信息写入数据库
  • 怎样把一个String写入数据库的大文本字段(Memo)?
  • Android实现将已发送的短信写入短信数据库的方法
  • 谁能告诉我具体怎么把html写入数据库再用document.write();显示出来!!!
  • 将复选框值赋于一变量写入一数据库问题
  • 数据库写不进去IIS写入权限怎么设置
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 并发数据库压力测试的shell脚本代码
  • 使用JAVA实现高并发无锁数据库操作步骤分享
  • Oracle 数据库针对表主键列并发导致行级锁简单演示
  • 基于Key-Value的NOSQL数据库Redis的数据结构及常用相关命令介绍
  • 如何监控数据库的数据,如果数据库数据更改,就通知Server
  • SQL Server 2008如何进行数据库分离和附加详细介绍
  • 散分:Jbuilder6开发数据库应用请问你们都用什么数据库? 免费的数据库有那些?
  • 文档数据库mongodb与列式数据库hbase详细比较
  • 如何从数据库中或文本文件中提取数据到另一个数据库中?
  • nosql数据库levedb介绍及levedb最新版1.18下载安装
  • 用JDBC连接Oracle数据库时,如何向数据库中写日期型数据(格式)?谢了!
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 开发java下的数据库程序,用什么数据库引擎?
  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式
  • 我从JSP页将数据插入到oracle数据库中,为何汉字插入后数据库中显示为乱码呢?
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • sql 语句 取数据库服务器上所有数据库的名字
  • 删除数据库中重复记录方法介绍及代码参考
  • 请问Linux数据库编程是否也可以支持通用的SQL语言进行数据库编写.
  • Mongodb数据库服务的开启与关闭详细介绍
  • 数据在页面写不进数据库,也不可以从数据库中读出是什么原因?
  • 如何实现 coreos 下Docker 与分布式数据库结合
  • sql语句获取数据库服务器上所有数据库的名字
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 请问谁有Applet连接远程Access数据库并且显示数据库内容的例子!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3