欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python基礎(chǔ)之操作MySQL數(shù)據(jù)庫(kù)

 更新時(shí)間:2021年05月06日 15:53:48   作者:拿頭來堅(jiān)持  
這篇文章主要介紹了Python基礎(chǔ)之操作MySQL數(shù)據(jù)庫(kù),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下

一、數(shù)據(jù)庫(kù)操作

1.1 安裝PyMySQL

pip install PyMySQL

1.2 連接數(shù)據(jù)庫(kù)

python連接test數(shù)據(jù)庫(kù)

import pymysql

host = 'localhost'      # 主機(jī)地址
username = 'root'       # 數(shù)據(jù)庫(kù)用戶名
password = ''           # 數(shù)據(jù)庫(kù)密碼
db_name = 'test'        # 數(shù)據(jù)庫(kù)名稱

# 創(chuàng)建connect對(duì)象
connect = pymysql.connect(host=host, user=username, password=password, database=db_name)

# 獲取游標(biāo)對(duì)象
cursor = connect.cursor()

# 查詢數(shù)據(jù)庫(kù)版本
cursor.execute('SELECT VERSION()')

# 從查詢結(jié)果集中獲取下一行數(shù)據(jù),返回值為一個(gè)值的序列
result = cursor.fetchone()

# 打印結(jié)果
print(result)

# 關(guān)閉游標(biāo)
cursor.close()

# 關(guān)閉數(shù)據(jù)庫(kù)連接
connect.close()

執(zhí)行結(jié)果:
('10.4.17-MariaDB',)

1.3 創(chuàng)建數(shù)據(jù)表

創(chuàng)建一個(gè)默認(rèn)編碼格式為utf8的數(shù)據(jù)表users

id:int類型,不能為空,有自增屬性,主鍵約束

name:varchar類型,長(zhǎng)度最多為10字符,可以為空

age:int類型,可以為空

import pprint
import pymysql

host = 'localhost'      # 主機(jī)地址
username = 'root'       # 數(shù)據(jù)庫(kù)用戶名
password = ''           # 數(shù)據(jù)庫(kù)密碼
db_name = 'test'        # 數(shù)據(jù)庫(kù)名稱

# 創(chuàng)建connect對(duì)象
connect = pymysql.connect(host=host, user=username, password=password, database=db_name)

# 獲取游標(biāo)對(duì)象
cursor = connect.cursor()

# 創(chuàng)建數(shù)據(jù)表的SQL命令
create_sql = '''
CREATE TABLE `users`(
    `id` INT NOT NULL AUTO_INCREMENT,
    `name` VARCHAR(10) NULL,
    `age` INT NULL,
    PRIMARY KEY (`id`))
    DEFAULT CHARACTER SET = utf8;
'''
# 創(chuàng)建數(shù)據(jù)表
cursor.execute(create_sql)

# 查詢我們創(chuàng)建的數(shù)據(jù)表的結(jié)構(gòu)
cursor.execute('DESC users')

# 從查詢結(jié)果中獲取結(jié)果的所有(或者剩余)行數(shù)據(jù),返回值為包含序列的序列(例如元組序列)
result = cursor.fetchall()

# 打印結(jié)果
pprint.pprint(result)

# 關(guān)閉游標(biāo)
cursor.close()

# 關(guān)閉數(shù)據(jù)庫(kù)連接
connect.close()

執(zhí)行結(jié)果:
(('id', 'int(11)', 'NO', 'PRI', None, 'auto_increment'),
 ('name', 'varchar(10)', 'YES', '', None, ''),
 ('age', 'int(11)', 'YES', '', None, ''))

在這里插入圖片描述

1.4 插入,查詢數(shù)據(jù)

插入3行數(shù)據(jù):

id:1,name:路飛,age:18
id:2,name:娜美,age:19
id:3,name:索隆,age:20

import pprint
import pymysql

host = 'localhost'      # 主機(jī)地址
username = 'root'       # 數(shù)據(jù)庫(kù)用戶名
password = ''           # 數(shù)據(jù)庫(kù)密碼
db_name = 'test'        # 數(shù)據(jù)庫(kù)名稱

# 創(chuàng)建connect對(duì)象,插入中文時(shí)需要指定編碼格式
connect = pymysql.connect(host=host, user=username, password=password, database=db_name, charset='utf8')

# 獲取游標(biāo)對(duì)象查詢返回字典
cursor = connect.cursor(pymysql.cursors.DictCursor)

# 插入數(shù)據(jù)的SQL命令
insert_sql = '''
INSERT INTO users (id, name, age)
    VALUES (1, '路飛', 18),(2, '娜美', 19),(3, '索隆', 20)
'''

try:
    # 插入數(shù)據(jù)到數(shù)據(jù)表
    cursor.execute(insert_sql)
    # 提交任何掛起的事務(wù)到數(shù)據(jù)庫(kù)
    connect.commit()
except Exception as e:
    # 發(fā)送數(shù)據(jù)回滾,回滾到事務(wù)開始時(shí)的狀態(tài)
    connect.rollback()

# 查詢數(shù)據(jù)
cursor.execute('SELECT * FROM users')

# 只返回一行數(shù)據(jù)
# result_one = cursor.fetchone()
# print('---fetchone---')
# pprint.pprint(result_one)

# 返回全部數(shù)據(jù)
result_all = cursor.fetchall()
print('---fetchall---')
pprint.pprint(result_all)

# 關(guān)閉游標(biāo)
cursor.close()

# 關(guān)閉數(shù)據(jù)庫(kù)連接
connect.close()

執(zhí)行結(jié)果:
---fetchall---
[{'age': 18, 'id': 1, 'name': '路飛'},
 {'age': 19, 'id': 2, 'name': '娜美'},
 {'age': 20, 'id': 3, 'name': '索隆'}]

在這里插入圖片描述

1.5 更新,查詢數(shù)據(jù)

更新數(shù)據(jù)id:3,name:山治,age:21

import pprint
import pymysql

host = 'localhost'      # 主機(jī)地址
username = 'root'       # 數(shù)據(jù)庫(kù)用戶名
password = ''           # 數(shù)據(jù)庫(kù)密碼
db_name = 'test'        # 數(shù)據(jù)庫(kù)名稱

# 創(chuàng)建connect對(duì)象,插入中文時(shí)需要指定編碼格式
connect = pymysql.connect(host=host, user=username, password=password, database=db_name, charset='utf8')

# 獲取游標(biāo)對(duì)象查詢返回字典
cursor = connect.cursor(pymysql.cursors.DictCursor)

# 查詢數(shù)據(jù)
cursor.execute('SELECT * FROM users')

# 返回更新前全部數(shù)據(jù)
result_all = cursor.fetchall()
print('---更新前---')
pprint.pprint(result_all)

# 更新數(shù)據(jù)的SQL命令
update_sql = '''
	UPDATE users SET name = '山治',age = 21 WHERE id = 3
'''

try:
    # 更新數(shù)據(jù)到數(shù)據(jù)表
    cursor.execute(update_sql)
    # 提交任何掛起的事務(wù)到數(shù)據(jù)庫(kù)
    connect.commit()
except Exception as e:
    # 發(fā)送數(shù)據(jù)回滾,回滾到事務(wù)開始時(shí)的狀態(tài)
    connect.rollback()

# 查詢數(shù)據(jù)
cursor.execute('SELECT * FROM users')

# 返回更新后全部數(shù)據(jù)
result_all = cursor.fetchall()
print('---更新后---')
pprint.pprint(result_all)

# 關(guān)閉游標(biāo)
cursor.close()

# 關(guān)閉數(shù)據(jù)庫(kù)連接
connect.close()

執(zhí)行結(jié)果:
---更新前---
[{'age': 18, 'id': 1, 'name': '路飛'},
 {'age': 19, 'id': 2, 'name': '娜美'},
 {'age': 20, 'id': 3, 'name': '索隆'}]
---更新后---
[{'age': 18, 'id': 1, 'name': '路飛'},
 {'age': 19, 'id': 2, 'name': '娜美'},
 {'age': 21, 'id': 3, 'name': '山治'}]

在這里插入圖片描述

1.6 刪除,查詢數(shù)據(jù)

刪除'age': 19, 'id': 2, 'name': '娜美'該行數(shù)據(jù)

import pprint
import pymysql

host = 'localhost'      # 主機(jī)地址
username = 'root'       # 數(shù)據(jù)庫(kù)用戶名
password = ''           # 數(shù)據(jù)庫(kù)密碼
db_name = 'test'        # 數(shù)據(jù)庫(kù)名稱

# 創(chuàng)建connect對(duì)象,插入中文時(shí)需要指定編碼格式
connect = pymysql.connect(host=host, user=username, password=password, database=db_name, charset='utf8')

# 獲取游標(biāo)對(duì)象查詢返回字典
cursor = connect.cursor(pymysql.cursors.DictCursor)

# 查詢數(shù)據(jù)
cursor.execute('SELECT * FROM users')

# 返回刪除前全部數(shù)據(jù)
result_all = cursor.fetchall()
print('---刪除前---')
pprint.pprint(result_all)

# 刪除數(shù)據(jù)的SQL命令
update_sql = '''
	DELETE FROM users WHERE id = 2
'''

try:
    # 刪除數(shù)據(jù)表的數(shù)據(jù)
    cursor.execute(update_sql)
    # 提交任何掛起的事務(wù)到數(shù)據(jù)庫(kù)
    connect.commit()
except Exception as e:
    # 發(fā)送數(shù)據(jù)回滾,回滾到事務(wù)開始時(shí)的狀態(tài)
    connect.rollback()

# 查詢數(shù)據(jù)
cursor.execute('SELECT * FROM users')

# 返回刪除后全部數(shù)據(jù)
result_all = cursor.fetchall()
print('---刪除后---')
pprint.pprint(result_all)

# 關(guān)閉游標(biāo)
cursor.close()

# 關(guān)閉數(shù)據(jù)庫(kù)連接
connect.close()

執(zhí)行結(jié)果:
---刪除前---
[{'age': 18, 'id': 1, 'name': '路飛'},
 {'age': 19, 'id': 2, 'name': '娜美'},
 {'age': 21, 'id': 3, 'name': '山治'}]
---刪除后---
[{'age': 18, 'id': 1, 'name': '路飛'}, {'age': 21, 'id': 3, 'name': '山治'}]

在這里插入圖片描述

二、連接與游標(biāo)對(duì)象的方法

2.1 連接對(duì)象的方法

  • .close()方法:

馬上關(guān)閉數(shù)據(jù)連接(而不是當(dāng)__del__方法被調(diào)用的時(shí)候)。此后連接變得不可用,再次訪問本連接對(duì)象會(huì)觸發(fā)一個(gè)錯(cuò)誤,使用本連接對(duì)象的游標(biāo)對(duì)象,也會(huì)導(dǎo)致例外發(fā)生。在關(guān)閉連接對(duì)象之前,沒有提交(commit)對(duì)數(shù)據(jù)庫(kù)的改變將會(huì)導(dǎo)致一個(gè)隱含的回滾動(dòng)作(rollback),這將丟棄之前的數(shù)據(jù)改變操作。

  • .commit()方法:

提交任何掛起的事務(wù)到數(shù)據(jù)庫(kù)中。

  • .rollback()方法:

對(duì)于支持事務(wù)的數(shù)據(jù)庫(kù)。調(diào)用此方法將導(dǎo)致數(shù)據(jù)庫(kù)回滾到事務(wù)開始時(shí)的狀態(tài)。

  • .cursor()方法:

方法返回給定連接上建立的游標(biāo)對(duì)象(Cursor Object),如果數(shù)據(jù)庫(kù)沒有提供對(duì)應(yīng)的游標(biāo)對(duì)象,那么有程序來模擬實(shí)現(xiàn)游標(biāo)功能。

2.2 游標(biāo)對(duì)象的方法

  • .close()方法:

立即關(guān)閉游標(biāo)(不論__del__方法是否已被調(diào)用),此后游標(biāo)對(duì)象就變得不可用了。

  • .execute(operation[,parameters])方法:

準(zhǔn)備和執(zhí)行數(shù)據(jù)庫(kù)操作。所提供的參數(shù)將會(huì)被綁定到語句中的變量,變量的定義和數(shù)據(jù)庫(kù)模塊有關(guān)。

  • .executemany(operation,seq_of_parameters)方法:

準(zhǔn)備和執(zhí)行數(shù)據(jù)庫(kù)操作,然后以序列形式的函數(shù)來執(zhí)行該操作。

  • .fetchone()方法:

從查詢結(jié)果中獲取下一行數(shù)據(jù),返回值為一個(gè)值的序列,如果沒有更多數(shù)據(jù)則返回None。

  • .fetchmany([size=cursor.arraysize])方法:

從查詢結(jié)果中獲取下一組行數(shù)據(jù),返回值為包含序列的序列,如果沒有數(shù)據(jù)返回時(shí),則返回空序列。每次調(diào)用要獲取的行數(shù)由參數(shù)指定,如果沒有指定行數(shù),則游標(biāo)的arraysize屬性決定要獲取的行數(shù)。

  • .fetchall()方法:

從查詢結(jié)果中獲取所有(或者剩余)行數(shù)據(jù),返回值為包含序列的序列。

  • .nextset()方法:

此方法將游標(biāo)跳到下一個(gè)可用的結(jié)果集并丟棄當(dāng)前結(jié)果集的所有行,如果沒有更有查詢結(jié)果集則返回None,否則返回True,接下來的fetch操作將會(huì)從新結(jié)果集返回?cái)?shù)據(jù)了。

  • .setinputsizes(sizes)方法:

此方法可用在調(diào)用.execute系列方法之前使用,用于預(yù)定義內(nèi)存區(qū)域。size參數(shù)接收一個(gè)序列類型的值,每一個(gè)元素對(duì)應(yīng)一個(gè)輸入?yún)?shù),該元素應(yīng)該是一個(gè)類型對(duì)象,對(duì)于將要使用的參數(shù),或者是一個(gè)整數(shù),用于指定字符串的最大長(zhǎng)度。如果元素是None,則沒有預(yù)定義的內(nèi)存區(qū)域作為保留區(qū)域。

  • .setoutputsize(size[,column])方法:

為一個(gè)很大的列設(shè)置緩沖區(qū)大小,不指定將使用默認(rèn)大小。

三、事務(wù)

事務(wù)是數(shù)據(jù)庫(kù)管理系統(tǒng)執(zhí)行過程中的一個(gè)邏輯單位,由一個(gè)有限的數(shù)據(jù)庫(kù)操作序列構(gòu)成,事務(wù)的目的性是為了保證數(shù)據(jù)的一致性。假設(shè)銀行轉(zhuǎn)賬操作,從A賬戶轉(zhuǎn)賬100元到B賬戶需要進(jìn)行至少兩次的數(shù)據(jù)庫(kù)修改操作,A賬戶余額需要減少100元,B賬戶余額需要增加100元,如果因?yàn)橛捎谕獠吭驅(qū)е鲁绦蛞馔饨K止,就會(huì)操作數(shù)據(jù)出錯(cuò),事務(wù)就是防止此情況的發(fā)生。

數(shù)據(jù)庫(kù)事務(wù)擁有四個(gè)特性,習(xí)慣稱之為ACID特性:

1、原子性(Atomicity):事務(wù)作為一個(gè)整體被執(zhí)行,包含在其中的對(duì)數(shù)據(jù)庫(kù)的操作要么全部被執(zhí)行,要么不執(zhí)行。
2、一致性(Consistency):事務(wù)應(yīng)確保數(shù)據(jù)庫(kù)的狀態(tài)從一個(gè)一致狀態(tài)轉(zhuǎn)變?yōu)榱硪粋€(gè)一致狀態(tài),一致狀態(tài)的含義是數(shù)據(jù)庫(kù)中的數(shù)據(jù)應(yīng)滿足完整性約束。
3、隔離性(Isolation):多個(gè)事務(wù)并發(fā)執(zhí)行時(shí),一個(gè)事務(wù)的執(zhí)行不應(yīng)影響其他事務(wù)的執(zhí)行。
4、持久性(Durability):已被提交的事務(wù)對(duì)數(shù)據(jù)庫(kù)的修改應(yīng)該永久保存在數(shù)據(jù)庫(kù)中。

import pprint
import pymysql

host = 'localhost'      # 主機(jī)地址
username = 'root'       # 數(shù)據(jù)庫(kù)用戶名
password = ''           # 數(shù)據(jù)庫(kù)密碼
db_name = 'test'        # 數(shù)據(jù)庫(kù)名稱

# 創(chuàng)建connect對(duì)象,插入中文時(shí)需要指定編碼格式
connect = pymysql.connect(host=host, user=username, password=password, database=db_name, charset='utf8')

# 獲取游標(biāo)對(duì)象查詢返回字典
cursor = connect.cursor(pymysql.cursors.DictCursor)

# 正確的插入數(shù)據(jù)的SQL命令
insert_sql1 = '''
INSERT INTO users (name, age)
    VALUES ('羅賓', 18),('喬巴', 16)
'''

# 錯(cuò)誤的插入數(shù)據(jù)的SQL命令
insert_sql2 = '''
INSERT INTO users (name, age)
    VALUES ('弗蘭奇')
'''

try:
    # 插入數(shù)據(jù)到數(shù)據(jù)表
    cursor.execute(insert_sql1)
    cursor.execute(insert_sql2)
    # 提交任何掛起的事務(wù)到數(shù)據(jù)庫(kù)
    connect.commit()
except Exception as e:
    # 執(zhí)行失敗發(fā)送數(shù)據(jù)回滾,回滾到事務(wù)開始時(shí)的狀態(tài)
    connect.rollback()

# 查詢數(shù)據(jù)
cursor.execute('SELECT * FROM users')

# 返回全部數(shù)據(jù)
result_all = cursor.fetchall()
print('---fetchall---')
pprint.pprint(result_all)

# 關(guān)閉游標(biāo)
cursor.close()

# 關(guān)閉數(shù)據(jù)庫(kù)連接
connect.close()

上例中執(zhí)行了兩條SQL語句,一條正確的一條錯(cuò)誤的,只要有一個(gè)錯(cuò)誤,兩條都不會(huì)生效,rollback方法會(huì)回滾當(dāng)前游標(biāo)的所有操作。

到此這篇關(guān)于Python基礎(chǔ)之操作MySQL數(shù)據(jù)庫(kù)的文章就介紹到這了,更多相關(guān)Python操作MySQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python中通用的文本相似度計(jì)算方法詳解

    Python中通用的文本相似度計(jì)算方法詳解

    這篇文章主要為大家詳細(xì)介紹了三種Python中通用的文本相似度計(jì)算方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-04-04
  • python查看矩陣的行列號(hào)以及維數(shù)方式

    python查看矩陣的行列號(hào)以及維數(shù)方式

    這篇文章主要介紹了python查看矩陣的行列號(hào)以及維數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Numpy中vstack()和hstack()的使用方式

    Numpy中vstack()和hstack()的使用方式

    文章詳細(xì)介紹了Numpy中vstack()和hstack()兩種數(shù)組拼接方法,vstack()是垂直堆疊數(shù)組,需保證除第一軸(行)外,數(shù)組形狀相同,hstack()是按順序堆疊數(shù)組,需保證除第二軸(列)外,數(shù)組形狀相同,兩者都可通過堆疊給定數(shù)組最后形成至少二維的數(shù)組
    2024-10-10
  • Python編寫一個(gè)驗(yàn)證碼圖片數(shù)據(jù)標(biāo)注GUI程序附源碼

    Python編寫一個(gè)驗(yàn)證碼圖片數(shù)據(jù)標(biāo)注GUI程序附源碼

    這篇文章主要介紹了Python編寫一個(gè)驗(yàn)證碼圖片數(shù)據(jù)標(biāo)注GUI程序,本文給大家附上小編精心整理的源碼,需要的朋友可以參考下
    2019-12-12
  • Python教程之無限迭代器的使用詳解

    Python教程之無限迭代器的使用詳解

    Python的Itetool是一個(gè)模塊,它提供了各種函數(shù),這些函數(shù)在迭代器上工作以產(chǎn)生復(fù)雜的迭代器。該模塊作為一個(gè)快速,內(nèi)存效率的工具,可以單獨(dú)使用或組合使用以形成迭代器代數(shù)。本文就來和大家詳細(xì)聊聊無限迭代器,感興趣的可以了解一下
    2022-09-09
  • python之生產(chǎn)者消費(fèi)者模型實(shí)現(xiàn)詳解

    python之生產(chǎn)者消費(fèi)者模型實(shí)現(xiàn)詳解

    這篇文章主要介紹了python之生產(chǎn)者消費(fèi)者模型實(shí)現(xiàn)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • python安裝及變量名介紹詳解

    python安裝及變量名介紹詳解

    這篇文章主要介紹了python安裝及變量名介紹詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • python讀取和保存視頻文件

    python讀取和保存視頻文件

    這篇文章主要為大家詳細(xì)介紹了python讀取顯示和保存視頻文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • 使用Python來編寫HTTP服務(wù)器的超級(jí)指南

    使用Python來編寫HTTP服務(wù)器的超級(jí)指南

    這篇文章主要介紹了使用Python來編寫HTTP服務(wù)器的超級(jí)指南,同時(shí)介紹了基于Python框架的web服務(wù)器的編寫方法,譯文從理論到實(shí)現(xiàn)講得都很生動(dòng)詳細(xì),十分推薦!需要的朋友可以參考下
    2016-02-02
  • 基于Python制作GIF表情包生成工具

    基于Python制作GIF表情包生成工具

    在當(dāng)前無表情包不會(huì)聊天的時(shí)代,怎么也不能輸在表情包數(shù)量不足上啊,今天咱們就來基于Python制作一個(gè)?gif?生成工具,用來制作表情包也太好用啦
    2023-07-07

最新評(píng)論