參考方法:
豐縣網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,豐縣網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為豐縣成百上千提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個(gè)售后服務(wù)好的豐縣做網(wǎng)站的公司定做!
delete from 表名;
truncate table 表名;
不帶where參數(shù)的delete語句可以刪除mysql表中所有內(nèi)容,使用truncate table也可以清空mysql表中所有內(nèi)容。效率上truncate比delete快,但truncate刪除后不記錄mysql日志,不可以恢復(fù)數(shù)據(jù)。
delete的效果有點(diǎn)像將mysql表中所有記錄一條一條刪除到刪完,而truncate相當(dāng)于保留mysql表的結(jié)構(gòu),重新創(chuàng)建了這個(gè)表,所有的狀態(tài)都相當(dāng)于新表。
一、使用phpmyadmin工具批量刪除mysql數(shù)據(jù)庫表
使用phpmyadmin數(shù)據(jù)庫管理工具進(jìn)行刪除,這是一個(gè)傳統(tǒng)的方法,在任何php虛擬主機(jī)中,你都可以操作。下面是操作過程介紹:
1、登錄phpmyadmin。選擇你的mysql數(shù)據(jù)庫名進(jìn)入——點(diǎn)擊結(jié)構(gòu)——選擇您要刪除的數(shù)據(jù)表——“選中項(xiàng)”中選擇刪除,執(zhí)行刪除表操作。如下圖:
PHPMYADMIN使用技巧:如何快速批量刪除Mysql數(shù)據(jù)庫中的數(shù)據(jù)表 image00114 150x150
二、使用php腳本完成批量刪除
無憂主機(jī)()小編從網(wǎng)上找了一段php代碼,也可以幫我們快速實(shí)現(xiàn)刪除。如果你對phpmyadmin工具“敏感”,可以使用下面的方式來實(shí)現(xiàn)快速刪除mysql數(shù)據(jù)庫表。 在下面的代碼復(fù)制到記事本后,配置過程中你要注意幾個(gè)問題:
1、 正確配置你mysql數(shù)據(jù)庫信息。這個(gè)你可以直接咨詢你的空間商就可以獲得啦。
2、 正確設(shè)置要刪除的數(shù)據(jù)庫表前綴,這個(gè)非常重要,填寫錯誤,將操作錯誤。請你務(wù)必確認(rèn)你的數(shù)據(jù)庫表前綴哦,數(shù)據(jù)庫表前綴你可以在phpmyadmin中查詢到。一般都是xx_開頭的。 設(shè)置好后,將這段代碼另存為.php文件(如51php.php)然后上傳到您空間的網(wǎng)站根目錄(public_html)。上傳完畢,直接用域名/51php.php,就可以刪除了。 代碼如下:
?php
mysql_connect('localhost','數(shù)據(jù)庫用戶名','數(shù)據(jù)庫密碼');
mysql_select_db('數(shù)據(jù)庫名稱');
$rs=mysql_query('show tables');
while($arr=mysql_fetch_array($rs))
{
$TF=strpos($arr[0],'51php_');
if($TF===0){
$FT=mysql_query("drop table $arr[0]");
if($FT){
echo "$arr[0] 刪除成功!br";
}
}
}
?
以上兩種方法都可批量刪除數(shù)據(jù)表,特別提醒一下,數(shù)據(jù)是無價(jià)的,操作數(shù)據(jù)表的時(shí)候一定要先做好備份。免得誤刪除數(shù)據(jù)是無法恢復(fù)的。如果您不會備份,麻煩您參考:
360度全方位講解無憂網(wǎng)站數(shù)據(jù)庫備份
Mysql數(shù)據(jù)庫管理利器:phpmyadmin詳細(xì)使用教程
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 語句的簡單說明:
這個(gè)語句之前我也沒有接觸過,也沒有使用過。因?yàn)橐话闱闆r下,刪除數(shù)據(jù)大家都在使用delete語句。其實(shí)這個(gè)truncate 命令很簡單,它的意思是:刪除表的所有記錄。相當(dāng)于 delete 語句不寫 where 子句一樣。其語法結(jié)構(gòu)為:
TRUNCATE?[TABLE]?tbl_name
這里簡單的給出個(gè)示例,我想刪除 friends 表中所有的記錄,可以使用如下語句:
truncate?table?friends;
truncate 和 delete的效率問題:
如果想要刪除表的所有數(shù)據(jù),truncate語句要比 delete 語句快。因?yàn)?truncate 刪除了表,然后根據(jù)表結(jié)構(gòu)重新建立它,而 delete 刪除的是記錄,并沒有嘗試去修改表。這也是為什么當(dāng)向一個(gè)使用 delete 清空的表插入數(shù)據(jù)時(shí),MySQL 會記住前面產(chǎn)生的AUTOINCREMENT序列,并且繼續(xù)利用它對AUTOINCREMENT字段編號。而truncate刪除表后,表是從1開始為autoincrement字段編號。
不過truncate命令快規(guī)快,卻不像delete命令那樣對事務(wù)處理是安全的。因此,如果我們想要執(zhí)行truncate刪除的表正在進(jìn)行事務(wù)處理,這個(gè)命令就會產(chǎn)生退出并產(chǎn)生錯誤信息。
操作步驟如下:
進(jìn)入phpmyadmin;
選擇要操作的數(shù)據(jù)庫;如下圖:
點(diǎn)擊刪除按鈕;如下圖:
點(diǎn)擊確定按鈕;如下圖:
數(shù)據(jù)庫刪除成功!
或者點(diǎn)擊SQL選項(xiàng)卡,輸入刪除命令,點(diǎn)擊執(zhí)行按鈕即可刪除數(shù)據(jù)庫。如下示例:
什么教數(shù)據(jù)全部歸0
我們假設(shè)數(shù)據(jù)庫中有三張表。
a,b,c,每個(gè)表有幾個(gè)字段,也有很多數(shù)據(jù),
那么你的問題到底是如下哪種
1:刪除掉該數(shù)據(jù)庫中的所有表,a,b,c
2:把所有表的數(shù)據(jù)都清空,表結(jié)構(gòu)保留
3:把表中所有的數(shù)據(jù)都變?yōu)檎螖?shù)值0?
補(bǔ)充1:
如果你是3的問題的話,實(shí)現(xiàn)起來比較繁瑣,并且我也不是很理解為什么要這樣做,感覺挺沒什么意義的,如果方便的話可以告訴我你的目的是什么,為什么要把所有的數(shù)據(jù)都變成0,或許可以換些辦法
補(bǔ)充2:
聽你的描述你可能是只有一個(gè)表,表中有很多的字段,每個(gè)字段都代表一個(gè)投票項(xiàng)目,而表中的數(shù)據(jù)記錄,其實(shí)只有一條?
你可以通過pg_num_fields獲得字段數(shù)量,在通過pg_field_name獲得字段名稱,依次運(yùn)行update
$dbconn = pg_connect("host=localhost");
$res = pg_query($dbconn, "select * from your_talbe_name");
$i = pg_num_fields($res);
for ($j = 0; $j $i; $j++) {
$fieldname = pg_field_name($res, $j);
pg_query($dbconn, "update your_talbe_name set $fieldname=0");
}
另外,我個(gè)人認(rèn)為你這樣實(shí)現(xiàn)投票的管理不是很好,投票項(xiàng)目一多很難管理,建議
create table xxx
(
id serial primary key,
name text,
num int
)
把投票項(xiàng)目的名字也就是你原來列的名稱放到name字段中,num則為投票數(shù),這樣以后再有這種問題,一個(gè)update xxx set num=0就OK了,管理起來也方便些。