日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
Python代碼一行搞定:清空所有數(shù)據(jù)庫(kù)表 (python清空所有數(shù)據(jù)庫(kù)表)

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

成都創(chuàng)新互聯(lián)公司始終堅(jiān)持【策劃先行,效果至上】的經(jīng)營(yíng)理念,通過(guò)多達(dá)10多年累計(jì)超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的全網(wǎng)整合營(yíng)銷(xiāo)推廣解決方案,現(xiàn)已廣泛運(yùn)用于各行各業(yè)的客戶,其中包括:成都汽車(chē)玻璃修復(fù)等企業(yè),備受客戶贊美。

一、需要安裝的庫(kù)

首先需要安裝pymysql庫(kù),pymysql是Python鏈接MySQL數(shù)據(jù)庫(kù)的庫(kù),是在Python 2.x和Python 3.x版本中的MySQL驅(qū)動(dòng)。其功能與Python MySQLdb庫(kù)相當(dāng),但效率更高,因?yàn)椴捎昧薓ySQL Connector Python庫(kù)中的C擴(kuò)展。我們可以使用pip來(lái)安裝pymysql庫(kù),命令如下:

“`

pip install pymysql

“`

安裝之后我們就可以在Python中使用pymysql庫(kù)來(lái)鏈接MySQL數(shù)據(jù)庫(kù)了。

二、準(zhǔn)備數(shù)據(jù)庫(kù)

為了驗(yàn)證我們的代碼,本文使用的是MySQL數(shù)據(jù)庫(kù),首先需要在數(shù)據(jù)庫(kù)中新建幾個(gè)測(cè)試表。這里我們新建三個(gè)表,表結(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ù)庫(kù)中查看三個(gè)測(cè)試表,如下圖所示:

![test_tables.png](https://cdn.nlark.com/yuque/0/2023/png/376705/1641918553044-0abe6841-5bbc-48f8-8f2e-e5a5b873de6e.png)

三、Python代碼一行搞定清空所有數(shù)據(jù)庫(kù)表

在Python中清空所有數(shù)據(jù)庫(kù)表只需要一行代碼即可,代碼如下:

“`python

import pymysql

# 登錄數(shù)據(jù)庫(kù)連接測(cè)試賬號(hào)

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庫(kù)來(lái)鏈接MySQL數(shù)據(jù)庫(kù),首先需要登錄數(shù)據(jù)庫(kù),使用下面的語(yǔ)句:

“`python

db = pymysql.connect(“l(fā)ocalhost”, “testuser”, “testpassword”, “testdb”)

“`

這里的localhost是MySQL所在的主機(jī)名,testuser和testpassword則是登錄MySQL的用戶名和密碼,testdb則是要使用的數(shù)據(jù)庫(kù)名。

接下來(lái),我們?cè)赑ython中執(zhí)行SQL語(yǔ)句清空所有的數(shù)據(jù)庫(kù)表,只需要以下代碼即可:

“`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設(shè)置為0,可以避免在清空外鍵時(shí)出現(xiàn)錯(cuò)誤。接著使用SHOW TABLES語(yǔ)句獲取所有表的名稱,然后使用循環(huán)將每個(gè)表都清空。由于SHOW TABLES語(yǔ)句返回的表名是一個(gè)元組,我們需要使用`table[0]`來(lái)獲取表名。最后將FOREIGN_KEY_CHECKS重新設(shè)置為1,并提交SQL事務(wù)。

代碼執(zhí)行成功后,我們可以在MySQL中查看到所有的表都已被清空,如下圖所示:

![database_cleared.png](https://cdn.nlark.com/yuque/0/2023/png/376705/1641919277259-05d12ee8-721f-4a24-bfbf-98bef52e141e.png)

本文介紹了如何通過(guò)Python代碼一行搞定清空所有數(shù)據(jù)庫(kù)表,只需要安裝pymysql庫(kù)并編寫(xiě)以上代碼即可輕松實(shí)現(xiàn)。清空數(shù)據(jù)庫(kù)表是一個(gè)非常常見(jiàn)的任務(wù),在實(shí)際工作中,我們可以根據(jù)需要定制相關(guān)的Python腳本來(lái)完成此任務(wù)。

相關(guān)問(wèn)題拓展閱讀:

  • Python操作mysql數(shù)據(jù)庫(kù)

Python操作mysql數(shù)據(jù)庫(kù)

你student表都DROP掉了,還想著往student表里插數(shù)據(jù)呢

要是真是照孫虧著書(shū)上寫(xiě)的那則塌神你快把書(shū)扔衫櫻了吧,太垃圾了

mysql里面 drop table AAA 是清空數(shù)據(jù)還是源迅畢刪除表?

如果是刪除表定義昌頌,你怎么查到?jīng)]有數(shù)據(jù)的?雹芹

關(guān)于python清空所有數(shù)據(jù)庫(kù)表的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。

成都網(wǎng)站營(yíng)銷(xiāo)推廣找創(chuàng)新互聯(lián),全國(guó)分站站群網(wǎng)站搭建更好做SEO營(yíng)銷(xiāo)。
創(chuàng)新互聯(lián)(www.cdcxhl.com)四川成都IDC基礎(chǔ)服務(wù)商,價(jià)格厚道。提供成都服務(wù)器托管租用、綿陽(yáng)服務(wù)器租用托管、重慶服務(wù)器托管租用、貴陽(yáng)服務(wù)器機(jī)房服務(wù)器托管租用。


名稱欄目:Python代碼一行搞定:清空所有數(shù)據(jù)庫(kù)表 (python清空所有數(shù)據(jù)庫(kù)表)
網(wǎng)站地址:http://www.5511xx.com/article/djiccoo.html