怎么在SQL语句SELECT的时候防止并发
需求大概是这样的:
做了一个判断,表里面该人的记录小于5次的时候可以执行INSERT操作。
但是可能会面临这样一个问题,SELECT的时候结果是小于5次的,但是其实已经有一条INSERT的语句在写表了。那么SELECT后又写表一条,发现这个人有6条记录了!
需求是怎么把这个SELECT5次的标准严格卡死,避免这种并发带来的误操作。
回复内容:
需求大概是这样的:
做了一个判断,表里面该人的记录小于5次的时候可以执行INSERT操作。
但是可能会面临这样一个问题,SELECT的时候结果是小于5次的,但是其实已经有一条INSERT的语句在写表了。那么SELECT后又写表一条,发现这个人有6条记录了!
需求是怎么把这个SELECT5次的标准严格卡死,避免这种并发带来的误操作。
使用存储过程
只要用插入锁把表锁了就是了。
<code>BEGIN SELECT COUNT(1) from wen_user for UPDATE INSERT into wen_user set name="3333333"; COMMIT</code>
可以使用for update来操作
可以使用mem锁机制实现
典型加锁解决方案
要想做到锁定行的同时还不影响性能,其实问题挺复杂的,不能简单的通过 select * for update 这种锁定读的方式来解决,需要根据你的问题的背景做一些测试,否则有可能会导致很多记录行都被锁定,导致整个系统运行缓慢。所以还是建议你把mysql的锁机制了解清楚,这样才能做到解决问题的同时还不影响性能。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법
