3 回答

TA貢獻1895條經驗 獲得超7個贊
MySQL為我們提供了delete和truncate語句來刪除數據。
delete 語句的定義:
刪除數據的時候用的大多都是 delete 語句?,F在讓我們來看一下 delete語句的定義。
DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name
[WHERE where_definition]
[ORDER BY ...]
[LIMIT row_count]
1 | delete from friends where user_name = 'simaopig' ; |
delete 注意事項:
從語法結構中,我們就可以看出,和 update 語法一樣,我們是可以省略 where 子句的。不過這是一個很危險的行為。因為如果不指定 where 子句,delete 將刪除表中所有的記錄,而且是立即刪除.
truncate 語句的簡單說明:
這個語句之前我也沒有接觸過,也沒有使用過。因為一般情況下,刪除數據大家都在使用delete語句。其實這個truncate 命令很簡單,它的意思是:刪除表的所有記錄。相當于 delete 語句不寫 where 子句一樣。其語法結構為:
TRUNCATE [TABLE] tbl_name
這里簡單的給出個示例,我想刪除 friends 表中所有的記錄,可以使用如下語句:
truncate table friends;
truncate 和 delete的效率問題:
如果想要刪除表的所有數據,truncate語句要比 delete 語句快。因為 truncate 刪除了表,然后根據表結構重新建立它,而 delete 刪除的是記錄,并沒有嘗試去修改表。這也是為什么當向一個使用 delete 清空的表插入數據時,MySQL 會記住前面產生的AUTOINCREMENT序列,并且繼續利用它對AUTOINCREMENT字段編號。而truncate刪除表后,表是從1開始為autoincrement字段編號。
不過truncate命令快規快,卻不像delete命令那樣對事務處理是安全的。因此,如果我們想要執行truncate刪除的表正在進行事務處理,這個命令就會產生退出并產生錯誤信息。

TA貢獻1803條經驗 獲得超3個贊
報什么錯了嗎?這樣,<?phprequire ('conn.php');$mesid=$_GET[mesid];$sql="delete from guestbook where MesID=".$msid;mysql_query($sql, conn);?>你要看下$mesid這個變量有沒有接受到值。

TA貢獻1785條經驗 獲得超8個贊
1,delete.php中用echo $mesid; 確認$mesid是否有值;如果沒有,那就是上一個頁面錯了。2,如果有值,那就是你的數據表中沒有MesID這個字段吧。因為你的sql語句是正確的。3,解決這個問題,最好貼出報錯語句
- 3 回答
- 0 關注
- 336 瀏覽
添加回答
舉報