如何将这些多个查询合并为一个(我可以吗?)
$query = "DELETE FROM aktywne_kody WHERE kodsms ='$kodSMSgracza' AND typkodu ='$id'";
mysql_query($query) or die(mysql_error());
$query = "INSERT INTO uzyte_kody (gracz, kodsms, typkodu) VALUES ('$nickGracza', '$kodSMSgracza', '$id')";
mysql_query($query) or die("B??d MySQL X04");
$query = "INSERT INTO do_odebrania (gracz, itemDATA, itemQTY) VALUES ('$nickGracza', '$itemDATA', '$itemQTY')";
mysql_query($query) or die("B??d MySQL X05");
所有查询完成后,如果我执行mysql_close($ db)会更好吗?
Hus*_*sni 31
传递65536给mysql_connect第5个参数.
例:
$conn = mysql_connect('localhost','username','password', true, 65536 /* here! */) 
    or die("cannot connect");
mysql_select_db('database_name') or die("cannot use database");
mysql_query("
    INSERT INTO table1 (field1,field2) VALUES(1,2);
    INSERT INTO table2 (field3,field4,field5) VALUES(3,4,5);
    DELETE FROM table3 WHERE field6 = 6;
    UPDATE table4 SET field7 = 7 WHERE field8 = 8;
    INSERT INTO table5
       SELECT t6.field11, t6.field12, t7.field13
       FROM table6 t6
       INNER JOIN table7 t7 ON t7.field9 = t6.field10;
    -- etc
");
使用mysql_fetch_*或mysql_num_rows或mysql_affected_rows时,只有第一个语句有效.
例如,下面的代码,第一个语句是INSERT,你不能执行mysql_num_rows和mysql_fetch_*.可以使用mysql_affected_rows返回插入的行数.
$conn = mysql_connect('localhost','username','password', true, 65536) or die("cannot connect");
mysql_select_db('database_name') or die("cannot use database");
mysql_query("
    INSERT INTO table1 (field1,field2) VALUES(1,2);
    SELECT * FROM table2;
");
另一个例子,下面的代码,第一个语句是SELECT,你不能执行mysql_affected_rows.但是您可以执行mysql_fetch_assoc来获取第一个SELECT语句产生的键值对,或者您可以执行mysql_num_rows以根据第一个SELECT语句获取行数.
$conn = mysql_connect('localhost','username','password', true, 65536) or die("cannot connect");
mysql_select_db('database_name') or die("cannot use database");
mysql_query("
    SELECT * FROM table2;
    INSERT INTO table1 (field1,field2) VALUES(1,2);
");