首先你的問題與PHP無關(guān),PHP總是把SQL語句不做任何解釋就教給數(shù)據(jù)庫,由數(shù)據(jù)庫管理系統(tǒng)進(jìn)行處理。
創(chuàng)新互聯(lián)的客戶來自各行各業(yè),為了共同目標(biāo),我們?cè)诠ぷ魃厦芮信浜?,從?chuàng)業(yè)型小企業(yè)到企事業(yè)單位,感謝他們對(duì)我們的要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。專業(yè)領(lǐng)域包括成都網(wǎng)站建設(shè)、網(wǎng)站制作、電商網(wǎng)站開發(fā)、微信營(yíng)銷、系統(tǒng)平臺(tái)開發(fā)。
其次你這樣的要求有什么意義呢,先刪除一個(gè)表再刪除一個(gè)表有什么問題呢?
最后是否可以執(zhí)行你這樣的功能,我現(xiàn)在使用過的數(shù)據(jù)庫都沒有相應(yīng)的語法同事刪除兩個(gè)表,要實(shí)現(xiàn)你這樣的功能可以兩個(gè)思路。一是建立一個(gè)存儲(chǔ)過程(PROCEDURE),調(diào)用這個(gè)存儲(chǔ)過程實(shí)現(xiàn)兩個(gè)表的數(shù)據(jù)刪除,但是本質(zhì)上是先后刪除的。另外一個(gè)辦法就是建立一個(gè)可以更新的試圖(VIEW),這個(gè)試圖是從兩個(gè)表里面獲取數(shù)據(jù)(比如CREATE v1 AS SELECT uid FROM A UNION SELECT uid FROM B),然后從這個(gè)試圖里面刪除數(shù)據(jù)(DELETE FROM v1 WHERE uid=$q_id)。
操作步驟如下:
進(jìn)入phpmyadmin;
選擇要操作的數(shù)據(jù)庫;如下圖:
點(diǎn)擊刪除按鈕;如下圖:
點(diǎn)擊確定按鈕;如下圖:
數(shù)據(jù)庫刪除成功!
或者點(diǎn)擊SQL選項(xiàng)卡,輸入刪除命令,點(diǎn)擊執(zhí)行按鈕即可刪除數(shù)據(jù)庫。如下示例:
$m?=?new?Model();
$m-query("drop?table?TABLENAME");?//?TABLENAME是要?jiǎng)h除的表名
php數(shù)據(jù)庫刪除表的時(shí)候怎么點(diǎn)都可以刪除成功是查詢執(zhí)行成功并影響到未返回任何行導(dǎo)致。根據(jù)查詢相關(guān)信息顯示對(duì)于其它類型的SQL語句,mysql,query()在執(zhí)行成功時(shí)返回TRUE,出錯(cuò)時(shí)返回FALSE。非FALSE的返回值意味著查詢是合法的并能夠被服務(wù)器執(zhí)行。導(dǎo)致php數(shù)據(jù)庫刪除表的時(shí)候任意點(diǎn)擊都可以刪除成功。
MySQL為我們提供了delete和truncate語句來刪除數(shù)據(jù)。
delete 語句的定義:
刪除數(shù)據(jù)的時(shí)候用的大多都是 delete 語句?,F(xiàn)在讓我們來看一下 delete語句的定義。
DELETE?[LOW_PRIORITY]?[QUICK]?[IGNORE]?FROM?tbl_name
[WHERE?where_definition]
[ORDER BY?...]
[LIMIT?row_count]
delete?from?friends?where?user_name?=?'simaopig';
delete 注意事項(xiàng):
從語法結(jié)構(gòu)中,我們就可以看出,和 update 語法一樣,我們是可以省略 where 子句的。不過這是一個(gè)很危險(xiǎn)的行為。因?yàn)槿绻恢付?where 子句,delete 將刪除表中所有的記錄,而且是立即刪除.
truncate 語句的簡(jiǎn)單說明:
這個(gè)語句之前我也沒有接觸過,也沒有使用過。因?yàn)橐话闱闆r下,刪除數(shù)據(jù)大家都在使用delete語句。其實(shí)這個(gè)truncate 命令很簡(jiǎn)單,它的意思是:刪除表的所有記錄。相當(dāng)于 delete 語句不寫 where 子句一樣。其語法結(jié)構(gòu)為:
TRUNCATE?[TABLE]?tbl_name
這里簡(jiǎn)單的給出個(gè)示例,我想刪除 friends 表中所有的記錄,可以使用如下語句:
truncate?table?friends;
truncate 和 delete的效率問題:
如果想要?jiǎng)h除表的所有數(shù)據(jù),truncate語句要比 delete 語句快。因?yàn)?truncate 刪除了表,然后根據(jù)表結(jié)構(gòu)重新建立它,而 delete 刪除的是記錄,并沒有嘗試去修改表。這也是為什么當(dāng)向一個(gè)使用 delete 清空的表插入數(shù)據(jù)時(shí),MySQL 會(huì)記住前面產(chǎn)生的AUTOINCREMENT序列,并且繼續(xù)利用它對(duì)AUTOINCREMENT字段編號(hào)。而truncate刪除表后,表是從1開始為autoincrement字段編號(hào)。
不過truncate命令快規(guī)快,卻不像delete命令那樣對(duì)事務(wù)處理是安全的。因此,如果我們想要執(zhí)行truncate刪除的表正在進(jìn)行事務(wù)處理,這個(gè)命令就會(huì)產(chǎn)生退出并產(chǎn)生錯(cuò)誤信息。