´ÓMySQLÖлñµÃÊý¾Ý±íauto_incrementÖµµÄ·½·¨
ÎÊÌâÊÇÕâÑùµÄ£ºÔÚ²åÈëÒ»ÐÐÊý¾Ýǰ¾ÍÏëÒªÖªµÀ½«Òª²úÉúµÄid¡£±ÈÈç˵ÏëÓÃÀ´ÃüÃûÉÏ´«µÄÎļþ¡£Èç¹û²»ÊÂÏÈ»ñµÃid¾Í²»ÖªµÀÎļþÃû£¬¾Íû·¨ÔÚ²åÈëʱ°ÑÎļþ·¾¶±£´æµ½Êý¾Ý¿âÀïÁË¡£Èç¹û²»ÐèÒªÊÂÏÈ»ñµÃid£¬´ó¿ÉÒÔÔÚ²åÈëºóµ÷ÓÃmysql_insert_id()»òÕßÖ´ÐÐselect last_insert_id()£¬¾Í²»±ØÍùÏ¿´ÁË¡£ÎªÁËÕÕ¹ËÐÔ¼±µÄͬѧ£¬Ïȸø´ð°¸£º
$result = mysql_query("show table status like 'tablename'");
$id = mysql_result($result, 0, 'Auto_increment');
ÆäÖÐtablenameÒª»»³ÉÊý¾Ý±íÃû£¬$id¾ÍÊÇauto_incrementÁеÄÏÂÒ»¸öÖµ¡£Ö»ÓÐÕâÖÖ°ì·¨ºÃÓã¬phpµÄ mysql_insert_id()£¬MySQLµÄselect last_insert_id()¡¢select @@last_insert_id¡¢select @@insert_id¡¢select @@identityÈ«¶¼²»ÐС£ÏëÖªµÀΪʲôµÄ»°¼ÌÐøÍùÏ¿´¡£
Ê×ÏÈÒª¸ãÇåÒ»µã£¬³ý·ÇÊÖ¶¯Ö¸¶¨£¬auto_incrementÊDz»ÓÃÖØ¸´ÖµµÄ¡£±ÈÈç˵Äãн¨Ò»ÕÅ±í£¬È»ºó²åÈë3ÐÐÊý¾Ý£¬idÖµÊÇ1¡¢2¡¢3£¬Ã»ÓÐÎÊÌâ¡£Èç¹ûÄã°Ñ2¡¢3ÄÇÁ½ÐÐɾµô£¬È»ºóÔÙ²åÈëÒ»ÐÐÊý¾Ý£¬ËüµÄidÖµÊǶàÉÙÄØ£¿ÊÇ2ô£¿ÊÇ4£¡Ò²ÐíÓеÄͬѧ»áÏ룺²»¶Ôѽ£¿MySQL²Î¿¼ÊÖ²áÉϲ»ÊÇдÁËô£º
µ±ÄúÏòÒ»¸öÒѱàÈëË÷ÒýµÄAUTO_INCREMENTÁÐÖвåÈëÒ»¸öNULLÖµ£¨½¨Ò飩»ò0ʱ£¬´ËÁб»ÉèÖÃΪÏÂÒ»¸öÐòÁеÄÖµ¡£Í¨³£Çé¿öÏÂΪvalue+1£¬´Ë´¦valueÊǵ±Ç°ÔÚ±íÖеÄÁеÄ×î´óÖµ¡£
û´í£¬µ«ÊÇMySQL²Î¿¼ÊÖ²áÉÏҲдÁË£º
Èç¹ûÄúɾ³ýµÄÐÐÖаüÀ¨ÓÃÓÚAUTO_INCREMENTÁеÄ×î´óÖµ£¬Ôò¸ÃÖµ±»ÖØÐÂÓÃÓÚBDB±í£¬µ«ÊDz»»á±»ÓÃÓÚMyISAM±í»òInnoDB±í¡£
BDBÊÇɶ£¿²éÁËһϣ¬ÊÇBerkeleyDB¡£ÎÒ¿´ÁËÒ»ÏÂÎÒµÄMySQL 5.0.51b£¬¸ù±¾ÕÒ²»µ½Õâ¸öÒýÇæ°¡¡£ÒÀÎÒ¿´£¬ÕâÁ½Ìõ¸ù±¾¾ÍÊÇ×ÔÏàì¶Ü£¬¶øÊÔÑéµÄ½á¹ûÊÇǰÕß´íºóÕß¶Ô¡£ËùÒÔÏÂÃæÕâÖÖд·¨¾Í²»ÐÐÁË£º
select max(id)+1 from tablename
ÄÇôphpµÄmysql_insert_id()º¯ÊýÄØ£¿phpÊÖ²áÉÏд×Å£º
Èç¹ûÉÏÒ»²éѯûÓвúÉúAUTO_INCREMENTµÄÖµ£¬Ôòmysql_insert_id()·µ»Ø0¡£
ÄÇôÈç¹û¸Õ¸Õɾ³ýÁËÒ»ÐÐÊý¾ÝÏÖÔÚÓÖÏë²åÈëÔõô°ìÄØ£¿ÏÔÈ»ÏëÔÚ²åÈëǰȡµ½ÖµÊDz»ÄÜÓÃËüµÄ¡£ÄÇôMySQLµÄlast_insert_id()º¯ÊýÄØ£¿MySQL²Î¿¼ÊÖ²áÀï˵£º
LAST_INSERT_ID() LAST_INSERT_ID(expr)
×Ô¶¯·µ»Ø×îºóÒ»¸öINSERT»òUPDATEÎÊѯΪAUTO_INCREMENTÁÐÉèÖõĵÚÒ»¸ö·¢ÉúµÄÖµ¡£
ÄÇôÈç¹ûÊÇÔÚµÚÒ»´Î²åÈëÊý¾ÝÖ®Ç°ÄØ£¿Èç¹ûÊý¾Ý·þÎñÆ÷ÖØÆôÁËÄØ£¿ÏÔȻҲ²»ÄÜÓ᣶øÇÒÆæ¹ÖµÄÊÇ£¬ÎÒÊÔÑéµÄ½á¹ûÊÇÕâ¸öº¯ÊýÒ»Ö±·µ»Ø0£¬²»ÖªÔõô¸ãµÄ¡£È«¾Ö±äÁ¿ÎÒÒ²ÊÔÁË£¬¸ö¸ö¶¼Îª0£¬ÕæÉñÁË¡£
×ÛÉÏ£¬Ö»ÓÐshow table status²»ÊÜÈÎ
Ïà¹ØÎĵµ£º
¸Õ¸Õ°²×°Íêmysqlºó
´ÓcmdÖнøÈëmysqlÊý¾Ý¿â
ÃüÁîÐÐÖÐÊäÈ룺
mysql -uroot -p123
½øÈëmysqlÊý¾Ý¿âÖÐ
ÃüÁîÐÐÖÐÊäÈë:
status;
²é¿´µ±Ç°Êý¾Ý¿âÖеıàÂë
ÈçÏ£º
--------------
mysql Ver 14.12 Distrib 5.1.7-beta, for Win32 (ia32)
Connection id: &nb ......
×÷Õߣº°½Ê¿Î°
·þÎñÆ÷£ºIBM X346
CPU:Intel Xeon 3.0 *4
Äڴ棺2GB
Ó²ÅÌ£ºRAID5
OS£ºwin2003 SE
Ò»¡¢MySQL 5.5 M2
MySQL ĬÈÏÒýÇæInnoDB£¬ÓÅ»¯Ç°ºó¼¸ºõÎÞ²î±ð
¶þ¡¢SQL SERVER 2000 SE
´ÓÕâû´Î²âÊÔ¿´£¬MysqlÔÚÊÂÎñÐÔÄܱíÏÖ²»ÈçSQL SERVER¡£Í¬Ê±£¬Á½ÕßÔÚĬÈÏÇé¿ö£¬ÅúÁ¿Insert£¬Mysql±íÏ ......
Ê×ÏÈ£¬½¨InnoDBÀàÐÍµÄ±í£¬²ÅÄÜÖ§³ÖÊÂÎñ
$handler = mysql_connect('localhost', '', '');
mysql_select_db('test');
mysql_query('SET AUTOCOMMIT=0'); // ÉèÖÃΪ²»×Ô¶¯Ìá½»²éѯ
mysql_query('START TRANSACTION'); // ¿ªÊ¼²éѯ£¬ÕâÀïÒ²¿ÉÒÔʹÓÃBEGIN
mysql_query("INSERT INTO users VALUES ('ccc')");
mysql_query( ......
<!--
/* Font Definitions */
@font-face
{font-family:ËÎÌå;
panose-1:2 1 6 0 3 1 1 1 1 1;
mso-font-alt:SimSun;
mso-font-charset:134;
mso-generic-font-family:auto;
mso-font-pitch:variable;
mso-font-signature:3 135135232 16 0 262145 0;}
@font-face
{font-family:"\@ËÎÌå" ......
×î½ü×öÒ»¸öСÏîÄ¿£¬¸ÕºÃÓöµ½Õâ¸öÎÊÌ⣬ûʲôʱ¼äÈ¥½â¾öÕâ¸öÎÊÌ⣬´ó¸ÅÔÚÍøÉÏÕÒÁËһϣ¬Ëµ¸ÄʵÀýÃû£¬¸Ä×¢²á±í£¬ÏȲ»ÊǺܸҸģ¬±Ï¾¹¶Ô×¢²á±íÒ»Ö±¾õµÃÊǸö´óÉñ£¬²»¸ÒËæ±ã¶¯£¬½ñ¶ùÊÇ»í³öÈ¥ÁË£¬¾ÍÔÚ×¢²á±íÖвéÕÒËùÓдúmysql×ÖÑùµÄÐÅϢȫ²¿É¾³ý£¬×îºó¾¹È»³ÉÁË£¬µ±È»Ð¶Ôغóɾ³ý֮ǰËùÓеÄÏà¹ØÐÅÏ¢£¬°²×°ÎļþÄ¿ ......