新聞中心
現(xiàn)代互聯(lián)網(wǎng)應用越來越需要運用到數(shù)據(jù)庫,而數(shù)據(jù)庫清空也成為了經(jīng)常需要處理的問題。當數(shù)據(jù)過多、數(shù)據(jù)結(jié)構(gòu)發(fā)生變化、測試環(huán)境準備等情況,我們需要清空數(shù)據(jù)庫表。但是,如果表數(shù)量很多,清空一個一個的非常耗時,而且容易出現(xiàn)遺漏。所以一般的做法是寫個清空數(shù)據(jù)庫的腳本,背景執(zhí)行即可。在Python中,只需要一行代碼即可完美解決,非常便捷,本文就讓我們來看看如何用Python一行搞定清空數(shù)據(jù)庫表。

成都創(chuàng)新互聯(lián)公司始終堅持【策劃先行,效果至上】的經(jīng)營理念,通過多達10多年累計超上千家客戶的網(wǎng)站建設總結(jié)了一套系統(tǒng)有效的全網(wǎng)整合營銷推廣解決方案,現(xiàn)已廣泛運用于各行各業(yè)的客戶,其中包括:成都汽車玻璃修復等企業(yè),備受客戶贊美。
一、需要安裝的庫
首先需要安裝pymysql庫,pymysql是Python鏈接MySQL數(shù)據(jù)庫的庫,是在Python 2.x和Python 3.x版本中的MySQL驅(qū)動。其功能與Python MySQLdb庫相當,但效率更高,因為采用了MySQL Connector Python庫中的C擴展。我們可以使用pip來安裝pymysql庫,命令如下:
“`
pip install pymysql
“`
安裝之后我們就可以在Python中使用pymysql庫來鏈接MySQL數(shù)據(jù)庫了。
二、準備數(shù)據(jù)庫
為了驗證我們的代碼,本文使用的是MySQL數(shù)據(jù)庫,首先需要在數(shù)據(jù)庫中新建幾個測試表。這里我們新建三個表,表結(jié)構(gòu)如下:
“`
CREATE TABLE `test1` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900__ci;
CREATE TABLE `test2` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900__ci;
CREATE TABLE `test3` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900__ci;
“`
新建完成后,我們可以在數(shù)據(jù)庫中查看三個測試表,如下圖所示:

三、Python代碼一行搞定清空所有數(shù)據(jù)庫表
在Python中清空所有數(shù)據(jù)庫表只需要一行代碼即可,代碼如下:
“`python
import pymysql
# 登錄數(shù)據(jù)庫連接測試賬號
db = pymysql.connect(“l(fā)ocalhost”, “testuser”, “testpassword”, “testdb”)
try:
with db.cursor() as cursor:
cursor.execute(“SET FOREIGN_KEY_CHECKS=0”)
cursor.execute(“SHOW TABLES”)
tables = cursor.fetchall()
for table in tables:
cursor.execute(f”TRUNCATE TABLE `{table[0]}`”)
cursor.execute(“SET FOREIGN_KEY_CHECKS=1”)
db.commit()
print(“Database tables have been truncated!”)
except Exception as e:
print(f”Fled to truncate all database tables! {repr(e)}”)
finally:
db.close()
“`
程序使用pymysql庫來鏈接MySQL數(shù)據(jù)庫,首先需要登錄數(shù)據(jù)庫,使用下面的語句:
“`python
db = pymysql.connect(“l(fā)ocalhost”, “testuser”, “testpassword”, “testdb”)
“`
這里的localhost是MySQL所在的主機名,testuser和testpassword則是登錄MySQL的用戶名和密碼,testdb則是要使用的數(shù)據(jù)庫名。
接下來,我們在Python中執(zhí)行SQL語句清空所有的數(shù)據(jù)庫表,只需要以下代碼即可:
“`python
with db.cursor() as cursor:
cursor.execute(“SET FOREIGN_KEY_CHECKS=0”)
cursor.execute(“SHOW TABLES”)
tables = cursor.fetchall()
for table in tables:
cursor.execute(f”TRUNCATE TABLE `{table[0]}`”)
cursor.execute(“SET FOREIGN_KEY_CHECKS=1”)
db.commit()
“`
首先將FOREIGN_KEY_CHECKS設置為0,可以避免在清空外鍵時出現(xiàn)錯誤。接著使用SHOW TABLES語句獲取所有表的名稱,然后使用循環(huán)將每個表都清空。由于SHOW TABLES語句返回的表名是一個元組,我們需要使用`table[0]`來獲取表名。最后將FOREIGN_KEY_CHECKS重新設置為1,并提交SQL事務。
代碼執(zhí)行成功后,我們可以在MySQL中查看到所有的表都已被清空,如下圖所示:

本文介紹了如何通過Python代碼一行搞定清空所有數(shù)據(jù)庫表,只需要安裝pymysql庫并編寫以上代碼即可輕松實現(xiàn)。清空數(shù)據(jù)庫表是一個非常常見的任務,在實際工作中,我們可以根據(jù)需要定制相關(guān)的Python腳本來完成此任務。
相關(guān)問題拓展閱讀:
- Python操作mysql數(shù)據(jù)庫
Python操作mysql數(shù)據(jù)庫
你student表都DROP掉了,還想著往student表里插數(shù)據(jù)呢
要是真是照孫虧著書上寫的那則塌神你快把書扔衫櫻了吧,太垃圾了
mysql里面 drop table AAA 是清空數(shù)據(jù)還是源迅畢刪除表?
如果是刪除表定義昌頌,你怎么查到?jīng)]有數(shù)據(jù)的?雹芹
關(guān)于python清空所有數(shù)據(jù)庫表的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。
成都網(wǎng)站營銷推廣找創(chuàng)新互聯(lián),全國分站站群網(wǎng)站搭建更好做SEO營銷。
創(chuàng)新互聯(lián)(www.cdcxhl.com)四川成都IDC基礎(chǔ)服務商,價格厚道。提供成都服務器托管租用、綿陽服務器租用托管、重慶服務器托管租用、貴陽服務器機房服務器托管租用。
新聞標題:Python代碼一行搞定:清空所有數(shù)據(jù)庫表 (python清空所有數(shù)據(jù)庫表)
URL分享:http://www.dlmjj.cn/article/djiccoo.html


咨詢
建站咨詢
