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

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

 更新時(shí)間:2017年03月05日 14:17:54   作者:前程明亮  
本篇文章主要介紹了python操作mysql數(shù)據(jù)庫(kù)的相關(guān)知識(shí),具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧

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

1. 想允許在數(shù)據(jù)庫(kù)寫中文,可在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)用下面命令

create database zcl charset utf8;

2. 查看students表結(jié)構(gòu)

desc students;

3. 查看創(chuàng)建students表結(jié)構(gòu)的語(yǔ)句

show create table students;

4. 刪除數(shù)據(jù)庫(kù)

drop database zcl;

5. 創(chuàng)建一個(gè)新的字段

alter table students add column nal char(64); 

PS: 本人是很討厭上面這種“簡(jiǎn)單解釋+代碼”的博客。其實(shí)我當(dāng)時(shí)在mysql終端寫了很多的實(shí)例,不過(guò)因?yàn)楫?dāng)時(shí)電腦運(yùn)行一個(gè)看視頻的軟件,導(dǎo)致我無(wú)法Ctrl+C/V?,F(xiàn)在懶了哈哈~~

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

python3不再支持mysqldb。其替代模塊是PyMySQL。本文的例子是在python3.4環(huán)境。

1. 安裝pymysql模塊

pip3 install pymysql

2. 連接數(shù)據(jù)庫(kù),插入數(shù)據(jù)實(shí)例

import pymysql
#生成實(shí)例,連接數(shù)據(jù)庫(kù)zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游標(biāo),當(dāng)前實(shí)例所處狀態(tài)
cur = conn.cursor()
#插入數(shù)據(jù)
reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Jack','man',25,1351234,"CN"))
reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Mary','female',18,1341234,"USA"))
conn.commit() #實(shí)例提交命令 
cur.close()
conn.close()
print(reCount)

查看結(jié)果:

mysql> select* from students;
+----+------+-----+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+------+-----+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
+----+------+-----+-----+-------------+------+
rows in set

3. 獲取數(shù)據(jù)

import pymysql
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
cur = conn.cursor()
reCount = cur.execute('select* from students')
res = cur.fetchone() #獲取一條數(shù)據(jù)
res2 = cur.fetchmany(3) #獲取3條數(shù)據(jù)
res3 = cur.fetchall() #獲取所有(元組格式)
print(res)
print(res2)
print(res3)
conn.commit()
cur.close()
conn.close()

輸出:

(1, 'zcl', 'man', 22, '15622341234', None)
((2, 'alex', 'man', 30, '15622341235', None), (5, 'Jack', 'man', 25, '1351234', 'CN'), (6, 'Mary', 'female', 18, '1341234', 'USA'))
()

三、事務(wù)回滾

事務(wù)回滾是在數(shù)據(jù)寫到數(shù)據(jù)庫(kù)前執(zhí)行的,因此事務(wù)回滾conn.rollback()要在實(shí)例提交命令conn.commit()之前。只要數(shù)據(jù)未提交就可以回滾,但回滾后ID卻是自增的。請(qǐng)看下面的例子:

插入3條數(shù)據(jù)(注意事務(wù)回滾):

import pymysql
#連接數(shù)據(jù)庫(kù)zcl
conn=pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游標(biāo),當(dāng)前實(shí)例所處狀態(tài)
cur=conn.cursor()
#插入數(shù)據(jù)
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Jack', 'man', 25, 1351234, "CN"))
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s,%s,%s,%s,%s)', ('Jack2', 'man', 25, 1351234, "CN"))
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Mary', 'female', 18, 1341234, "USA"))
conn.rollback() #事務(wù)回滾
conn.commit() #實(shí)例提交命令 
cur.close()
conn.close()
print(reCount)

未執(zhí)行命令前與執(zhí)行命令后(包含回滾操作)(注意ID號(hào)): 未執(zhí)行上面代碼與執(zhí)行上面代碼的結(jié)果是一樣的!!因?yàn)槭聞?wù)已經(jīng)回滾,故students表不會(huì)增加數(shù)據(jù)!

mysql> select* from students;
+----+------+--------+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+------+--------+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
| 5 | Jack | man | 25 | 1351234 | CN |
| 6 | Mary | female | 18 | 1341234 | USA |
+----+------+--------+-----+-------------+------+
rows in set

執(zhí)行命令后(不包含回滾操作):只需將上面第11行代碼注釋。

mysql> select* from students;
+----+-------+--------+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+-------+--------+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
| 5 | Jack | man | 25 | 1351234 | CN |
| 6 | Mary | female | 18 | 1341234 | USA |
| 10 | Jack | man | 25 | 1351234 | CN |
| 11 | Jack2 | man | 25 | 1351234 | CN |
| 12 | Mary | female | 18 | 1341234 | USA |
+----+-------+--------+-----+-------------+------+
rows in set

總結(jié):雖然事務(wù)回滾了,但I(xiàn)D還是自增了,不會(huì)因回滾而取消,但這不影響數(shù)據(jù)的一致性(底層的原理我不清楚~)

四、批量插入數(shù)據(jù)

import pymysql
#連接數(shù)據(jù)庫(kù)zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游標(biāo),當(dāng)前實(shí)例所處狀態(tài)
cur = conn.cursor()
li = [
 ("cjy","man",18,1562234,"USA"),
 ("cjy2","man",18,1562235,"USA"),
 ("cjy3","man",18,1562235,"USA"),
 ("cjy4","man",18,1562235,"USA"),
 ("cjy5","man",18,1562235,"USA"),
]
#插入數(shù)據(jù)
reCount = cur.executemany('insert into students(name,sex,age,tel,nal) values(%s,%s,%s,%s,%s)', li)
#conn.rollback() #事務(wù)回滾
conn.commit() #實(shí)例提交命令
cur.close()
conn.close()
print(reCount)

pycharm下輸出: 5

mysql終端顯示:

mysql> select* from students;   #插入數(shù)據(jù)前
+----+-------+--------+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+-------+--------+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
| 5 | Jack | man | 25 | 1351234 | CN |
| 6 | Mary | female | 18 | 1341234 | USA |
| 10 | Jack | man | 25 | 1351234 | CN |
| 11 | Jack2 | man | 25 | 1351234 | CN |
| 12 | Mary | female | 18 | 1341234 | USA |
+----+-------+--------+-----+-------------+------+
rows in set


mysql> 
mysql> select* from students;   #插入數(shù)據(jù)后
+----+-------+--------+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+-------+--------+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
| 5 | Jack | man | 25 | 1351234 | CN |
| 6 | Mary | female | 18 | 1341234 | USA |
| 10 | Jack | man | 25 | 1351234 | CN |
| 11 | Jack2 | man | 25 | 1351234 | CN |
| 12 | Mary | female | 18 | 1341234 | USA |
| 13 | cjy | man | 18 | 1562234 | USA |
| 14 | cjy2 | man | 18 | 1562235 | USA |
| 15 | cjy3 | man | 18 | 1562235 | USA |
| 16 | cjy4 | man | 18 | 1562235 | USA |
| 17 | cjy5 | man | 18 | 1562235 | USA |
+----+-------+--------+-----+-------------+------+
rows in set

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • Python pandas求方差和標(biāo)準(zhǔn)差的方法實(shí)例

    Python pandas求方差和標(biāo)準(zhǔn)差的方法實(shí)例

    標(biāo)準(zhǔn)差(或方差),分為 總體標(biāo)準(zhǔn)差(方差)和 樣本標(biāo)準(zhǔn)差(方差),下面這篇文章主要給大家介紹了關(guān)于pandas求方差和標(biāo)準(zhǔn)差的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-08-08
  • 關(guān)于Python操作Excel的基本方法

    關(guān)于Python操作Excel的基本方法

    這篇文章主要介紹了關(guān)于Python操作Excel的基本方法,Python是一種功能強(qiáng)大的編程語(yǔ)言,可以用于許多任務(wù),包括處理Excel文件,需要的朋友可以參考下
    2023-05-05
  • Python通過(guò)正則庫(kù)爬取淘寶商品信息代碼實(shí)例

    Python通過(guò)正則庫(kù)爬取淘寶商品信息代碼實(shí)例

    這篇文章主要介紹了Python通過(guò)正則庫(kù)爬取淘寶商品信息代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Python greenlet和gevent使用代碼示例解析

    Python greenlet和gevent使用代碼示例解析

    這篇文章主要介紹了Python greenlet和gevent使用代碼示例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • python使用numpy實(shí)現(xiàn)直方圖反向投影示例

    python使用numpy實(shí)現(xiàn)直方圖反向投影示例

    今天小編就為大家分享一篇python使用numpy實(shí)現(xiàn)直方圖反向投影示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • python之Socket網(wǎng)絡(luò)編程詳解

    python之Socket網(wǎng)絡(luò)編程詳解

    這篇文章主要為大家詳細(xì)介紹了python之Socket網(wǎng)絡(luò)編程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • python入門課程第二講之怎么運(yùn)行Python

    python入門課程第二講之怎么運(yùn)行Python

    這篇文章主要介紹了python入門課程第二講之怎么運(yùn)行Python,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • 一文詳解Python中PO模式的設(shè)計(jì)與實(shí)現(xiàn)

    一文詳解Python中PO模式的設(shè)計(jì)與實(shí)現(xiàn)

    在使用 Python 進(jìn)行編碼的時(shí)候,會(huì)使用自身自帶的編碼設(shè)計(jì)格式,比如說(shuō)最常見的單例模式等。本文將為大家介紹PageObject自動(dòng)化設(shè)計(jì)模式(PO模式)的設(shè)計(jì)與實(shí)現(xiàn),感興趣的可以了解一下
    2022-06-06
  • python實(shí)現(xiàn)sublime3的less編譯插件示例

    python實(shí)現(xiàn)sublime3的less編譯插件示例

    這篇文章主要介紹了python實(shí)現(xiàn)sublime3的less編譯插件示例的相關(guān)資料
    2014-04-04
  • 詳解Python語(yǔ)法之模塊Module

    詳解Python語(yǔ)法之模塊Module

    這篇文章主要為大家介紹了Python語(yǔ)法之模塊Module,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-12-12

最新評(píng)論