MySQL如何确认update,delete,insert语句成功执行?
如题,现在一直通过mysql_affected_rows()在判断,这样的话就造成几乎每一句update,delete,insert后面必然要跟一句
if(mysql_affected_rows()!=1)
{
报错
}
请问有什么更简便的办法吗?
回复讨论(解决方案)
mysql_affected_rows 不是用于检查执行是否成功的
而是用于观察相关 sql 指令对多少记录进行了操作
直接
if(执行sql语句){.....}else{......}
mysql_affected_rows 不是用于检查执行是否成功的
而是用于观察相关 sql 指令对多少记录进行了操作
是我表述问题。我就是想判断insert,delete,update语句成功地影响了至少1行
判断影响了几行mysql_affected_rows() 肯定是要执行的。
无论影响多少行(包括0行)都不是错误
无论影响多少行(包括0行)都不是错误
这我当然知道。。。
如题,现在一直通过mysql_affected_rows()在判断,这样的话就造成几乎每一句update,delete,insert后面必然要跟一句
if(mysql_affected_rows()!=1)
{
报错
}
请问有什么更简便的办法吗?
补充一下,我是要判断update,delete,insert语句至少影响了1行,似乎大部分情况下都需要这样的判断逻辑
就是因为即使update,delete,insert影响了0行,事务也不会回滚,所以会产生这个问题
update 没有符合条件的记录,就不会修改,如果被修改的值和原值一样,则修改不会真正发生
delete 没有符合条件的记录,就不会删除,如果有多条符合条件的记录,自然也就一并删除了
insert 只会影响一条,哪怕是用缩略写法的 insert 语句插入了 100 条
看不出这与事务有什么关系
update 没有符合条件的记录,就不会修改,如果被修改的值和原值一样,则修改不会真正发生
delete 没有符合条件的记录,就不会删除,如果有多条符合条件的记录,自然也就一并删除了
insert 只会影响一条,哪怕是用缩略写法的 insert 语句插入了 100 条
看不出这与事务有什么关系
想了一下,你说的有道理。
我把我的疑问举个例子:
比如用户要用虚拟货币购买虚拟物品,在update ... set money= ... where user_id=... 这条语句执行后,需不需要mysql_affected_rows()来验证成功update了1行呢?我担心没真正update到money字段,然后就执行了下面给该用户添加虚拟物品的业务
如果在之前执行了select money from ... for update,就能保证万无一失吗?
update 没有符合条件的记录,就不会修改,如果被修改的值和原值一样,则修改不会真正发生
delete 没有符合条件的记录,就不会删除,如果有多条符合条件的记录,自然也就一并删除了
insert 只会影响一条,哪怕是用缩略写法的 insert 语句插入了 100 条
看不出这与事务有什么关系
想了一下,你说的有道理。
我把我的疑问举个例子:
比如用户要用虚拟货币购买虚拟物品,在update ... set money= ... where user_id=... 这条语句执行后,需不需要mysql_affected_rows()来验证成功update了1行呢?我担心没真正update到money字段,然后就执行了下面给该用户添加虚拟物品的业务
如果在之前执行了select money from ... for update,就能保证万无一失吗?
直接if (update操作....){购买成功...}else{购买失败....}不就好了,update操作失败返回的是false
$result = mysql_query("update ……")if ($result !== false){ echo "exec success";}else{ echo "exec error:".mysql_error():}
update 没有符合条件的记录,就不会修改,如果被修改的值和原值一样,则修改不会真正发生
delete 没有符合条件的记录,就不会删除,如果有多条符合条件的记录,自然也就一并删除了
insert 只会影响一条,哪怕是用缩略写法的 insert 语句插入了 100 条
看不出这与事务有什么关系
想了一下,你说的有道理。
我把我的疑问举个例子:
比如用户要用虚拟货币购买虚拟物品,在update ... set money= ... where user_id=... 这条语句执行后,需不需要mysql_affected_rows()来验证成功update了1行呢?我担心没真正update到money字段,然后就执行了下面给该用户添加虚拟物品的业务
如果在之前执行了select money from ... for update,就能保证万无一失吗?
直接if (update操作....){购买成功...}else{购买失败....}不就好了,update操作失败返回的是false
好的我决定试一下,看起来比mysql_affected_rows简洁,不知道效果上有没有什么细微差别
$result = mysql_query("update ……")if ($result !== false){ echo "exec success";}else{ echo "exec error:".mysql_error():}
同上,谢谢,准备试一下效果
如果你不放心 update ... set money=money-1 会真实执行的话
那么你是否需要再 select 一下,确认 money 减少了 1,而不是减少了 100 呢?
$result = mysql_query("update ……")
只有在 sql 指令是错误的情况下,才会返回 false
所以并不需要去试
如果你不放心 update ... set money=money-1 会真实执行的话
那么你是否需要再 select 一下,确认 money 减少了 1,而不是减少了 100 呢?
$result = mysql_query("update ……")
只有在 sql 指令是错误的情况下,才会返回 false
所以并不需要去试
如果你不放心 update ... set money=money-1 会真实执行的话
那么你是否需要再 select 一下,确认 money 减少了 1,而不是减少了 100 呢?
$result = mysql_query("update ……")
只有在 sql 指令是错误的情况下,才会返回 false
所以并不需要去试
好的,感觉你说的听起来比较靠谱,谢谢。

핫 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)

뜨거운 주제











키보드 삭제 키에는 del(삭제) 키와 백스페이스 키라는 두 가지 키가 있습니다. 백스페이스는 백스페이스 키라고도 합니다. 이 키는 커서 앞의 텍스트 내용을 삭제할 수 있으며 삭제 키는 문자, 파일 및 선택한 개체를 삭제할 수 있습니다. del 키를 누를 때마다 커서 오른쪽에 있는 문자가 삭제되고, 하나 이상의 파일/폴더가 선택되면 커서 오른쪽에 있는 문자가 한 프레임 왼쪽으로 이동합니다. 키를 누르면 빠르게 삭제됩니다. 일부 응용 프로그램에서는 프로그램에서 개체를 선택하고 Del 키를 누르면 선택한 개체가 빠르게 삭제됩니다.

삭제 키의 기능은 다음과 같습니다. 1. 문자 삭제 삭제 키를 누를 때마다 커서 오른쪽에 있는 문자가 삭제되고 커서 오른쪽에 있는 문자가 왼쪽으로 한 프레임 이동합니다. 2. 파일을 삭제합니다. 하나 이상의 파일/폴더를 선택한 경우 삭제 키를 눌러 빠르게 삭제합니다(복구하려면 휴지통으로 이동). 3. 선택한 개체를 삭제합니다. 일부 응용 프로그램에서는 개체를 선택하고 삭제 키를 눌러 선택한 개체를 빠르게 삭제합니다.

Ctrl+Alt+Delete: "Mac" 모드 Ctrlaltdel은 Windows 사용자가 작업 관리자를 열 때 사용하는 일반적인 키 조합입니다. 그들은 일반적으로 컴퓨터의 일부 공간을 확보하기 위해 관리자 메뉴에서 원치 않는 응용 프로그램을 종료합니다. Control+Alt+Delete Mac 변형을 사용하면 강제 종료 메뉴를 열 수 있습니다. Mac 사용자가 문제를 일으키는 프로그램을 종료하거나 열려 있는 프로그램을 보려면 메뉴와 상호 작용하여 추가 조사를 수행할 수 있습니다. Mac에서 ControlAltDelete를 수행하는 방법은 무엇입니까? 응용 프로그램이 오작동하는 경우 이 키 조합을 사용해야 합니다.

삭제로 삭제된 파일은 복구가 가능합니다. 사용자가 삭제를 사용하여 파일을 삭제하면 해당 파일은 휴지통으로 이동되고 완전히 삭제되지는 않기 때문입니다. 복구 방법: 1. "휴지통"을 열고 복원할 파일을 선택한 다음 "이 항목 복원"을 클릭합니다. 2. "휴지통"을 열고 복원할 파일을 선택한 다음 실행 취소 단축키를 사용합니다. "ctrl+z"를 사용할 수 있습니다.

오늘날의 웹 개발 시대에는 특히 데이터가 많은 웹 애플리케이션을 다룰 때 효과적이고 효율적인 테이블 관리가 매우 중요해졌습니다. 테이블에서 행을 동적으로 추가, 편집 및 삭제하는 기능은 사용자 경험을 크게 향상시키고 애플리케이션을 보다 대화형으로 만들 수 있습니다. 이를 달성하는 효과적인 방법은 jQuery의 기능을 활용하는 것입니다. jQuery는 개발자가 작업을 수행하는 데 도움이 되는 많은 기능을 제공합니다. 테이블 행 테이블 행은 HTML의 요소로 표시되는 상호 연관된 데이터의 모음입니다. 테이블의 셀(요소로 표시)을 그룹화하는 데 사용됩니다. 각 요소는 테이블의 행을 정의하는 데 사용되며 다중 속성 테이블의 경우 일반적으로 하나 이상의 요소를 포함합니다. 구문$(선택기).append(co

PUT 및 삭제 요청은 Form 양식에서 사용되며 get 및 post 메소드만 지원합니다. put 메소드를 구현하려면 다음 세 단계를 구현할 수 있습니다. 1) SpringMVC에서 HiddenHttpMethodFilter 구성 2) 페이지에 게시 양식 생성 3) 이름이 ="_method"인 입력 항목을 만듭니다. 값은 지정된 요청 메서드입니다. HiddenHttpMethodFilter 클래스에서 "_method" 값을 가져와 새 요청 메서드를 가져옵니다. 번째 태그는 thymeleaf 템플릿입니다. 이는 직원이

데이터베이스 삭제 사용법: 1. 단일 레코드를 삭제합니다. 2. 여러 레코드를 삭제합니다. 3. 모든 레코드를 삭제합니다. 4. 특정 조건에서 레코드를 삭제합니다.

삭제 키의 기능은 다음과 같습니다. 1. 텍스트 삭제 2. 파일 삭제 3. 선택한 개체 삭제. 삭제 키는 일반적으로 키보드의 오른쪽 상단에 있습니다. 삭제 키를 누르면 커서 오른쪽에 있는 문자를 삭제할 수 있습니다.
