高并发下数据库插入重复数据

方法1:

ServiceA{
     // 根据username查询数据库中是否存在该数据
     Method isInDB(String username); 
     //保存用户
     Method saveUser() {
           boolean  flag = Method isInDB(username);
           if(!flag){
              //判断数据库中没有才 执行insert 操作
           }
     }
}

以上是我的java代码,我用loadrunner 进行压力测试,在saveuser前设置集合点,直接使用300用户并发操作,结果数据库会保存进许多重复username的记录,我自己从网上也查了许多资料有人给了我以下建议
1、保存用户逻辑采用储存过程操作,把并发压力交给数据库处理
2、数据库对username字段加上唯一约束,这样插入重复记录时 抛出异常,利用事务进行回滚
除了以上两种方法外,我想请大家给出第三种解决方案,其实这种就类似与高并发下的用户注册功能

方法2:

INSERT INTO the_table (cl1, cl2, ... , cln) SELECT cl1, cl2, ..., cln FROM (SELECT ? AS cl1, ? AS cl2, ... , ? AS cln) X WHERE NOT EXISTS ( SELECT id FROM the_table WHERE username=?)





猜你喜欢

转载自hck.iteye.com/blog/2197140