Heim > Backend-Entwicklung > PHP-Tutorial > 关于获取上一步insert的SQL语句的id的有关问题

关于获取上一步insert的SQL语句的id的有关问题

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-13 12:09:23
Original
1216 Leute haben es durchsucht

关于获取上一步insert的SQL语句的id的问题
用mysql_insert_id函数的话,当错作流程是:A页面插入了一条,id=1,B页面插入了一条,id=2,A页面执行mysql_insert_id获取到的id是1还是2?
------解决思路----------------------
A页面当然是 1
------解决思路----------------------
如果不是1 ,就麻烦了,那么写所有的东西,都要操心并发的问题了。
------解决思路----------------------
可以对mysql服务器发送查询

mysql_query("select  LAST_INSERT_ID()");
Nach dem Login kopieren
 如果是一万个页面呢?再如果是重要的事务性操作呢?查询数据库比较靠谱
------解决思路----------------------
A页面的mysql_insert_id返回是1

MySQL的mysql_insert_id是针对MySQL进程来进行的,对于服务器来说mysql_query都是一个原子操作,不是MAX(id),就算在大并发的情况下也不会出现不准确的情况。

可以看看MySQL的

mysql_insert_id是这么定义的

my_ulonglong STDCALL mysql_insert_id(MYSQL *mysql)
{
  return mysql->;last_used_con->;insert_id;
}

MYSQL参数是个结构体,里面包括数据库链接和一些当前数据库链接的状态值,

其中在MYSQL结构体里面有insert_id,mysql_insert_id函数返回的就是结构体里面的找个值。
------解决思路----------------------
肯定是1,自己可以实际操作一下,就明白了

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage