国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

如何使用python對數據庫(mysql)進行操作

來源:懂視網 責編:小采 時間:2020-11-27 14:24:58
文檔

如何使用python對數據庫(mysql)進行操作

如何使用python對數據庫(mysql)進行操作:一、數據庫基本操作1. 想允許在數據庫寫中文,可在創建數據庫時用下面命令create database zcl charset utf8;2. 查看students表結構desc students;3. 查看創建students表結構的語句show create table students;4. 刪除數據庫d
推薦度:
導讀如何使用python對數據庫(mysql)進行操作:一、數據庫基本操作1. 想允許在數據庫寫中文,可在創建數據庫時用下面命令create database zcl charset utf8;2. 查看students表結構desc students;3. 查看創建students表結構的語句show create table students;4. 刪除數據庫d

一、數據庫基本操作

1. 想允許在數據庫寫中文,可在創建數據庫時用下面命令

create database zcl charset utf8;

2. 查看students表結構

desc students;

3. 查看創建students表結構的語句

show create table students;

4. 刪除數據庫

drop database zcl;

5. 創建一個新的字段

alter table students add column nal char(64); 

PS: 本人是很討厭上面這種“簡單解釋+代碼”的博客。其實我當時在mysql終端寫了很多的實例,不過因為當時電腦運行一個看視頻的軟件,導致我無法Ctrl+C/V。現在懶了哈哈~~

二、python連接數據庫

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

1. 安裝pymysql模塊

pip3 install pymysql

2. 連接數據庫,插入數據實例

import pymysql
#生成實例,連接數據庫zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游標,當前實例所處狀態
cur = conn.cursor()
#插入數據
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() #實例提交命令

cur.close()
conn.close()
print(reCount)

查看結果:

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

3. 獲取數據

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() #獲取一條數據
res2 = cur.fetchmany(3) #獲取3條數據
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'))
()

三、事務回滾

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

插入3條數據(注意事務回滾):

import pymysql
#連接數據庫zcl
conn=pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游標,當前實例所處狀態
cur=conn.cursor()
#插入數據
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() #事務回滾
conn.commit() #實例提交命令

cur.close()
conn.close()
print(reCount)

未執行命令前與執行命令后(包含回滾操作)(注意ID號): 未執行上面代碼與執行上面代碼的結果是一樣的!!因為事務已經回滾,故students表不會增加數據!

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 |
+----+------+--------+-----+-------------+------+
4 rows in set

執行命令后(不包含回滾操作):只需將上面第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 |
+----+-------+--------+-----+-------------+------+
7 rows in set

總結:雖然事務回滾了,但ID還是自增了,不會因回滾而取消,但這不影響數據的一致性(底層的原理我不清楚~)

四、批量插入數據

import pymysql
#連接數據庫zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游標,當前實例所處狀態
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"),
]

#插入數據
reCount = cur.executemany('insert into students(name,sex,age,tel,nal) values(%s,%s,%s,%s,%s)', li)

#conn.rollback() #事務回滾
conn.commit() #實例提交命令

cur.close()
conn.close()
print(reCount)

pycharm下輸出: 5

mysql終端顯示:

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 |
+----+-------+--------+-----+-------------+------+
7 rows in set


mysql> 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 |
| 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 |
+----+-------+--------+-----+-------------+------+
12 rows in set

學完的東西要及時總結,有些東西忘記了阿~_~

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

如何使用python對數據庫(mysql)進行操作

如何使用python對數據庫(mysql)進行操作:一、數據庫基本操作1. 想允許在數據庫寫中文,可在創建數據庫時用下面命令create database zcl charset utf8;2. 查看students表結構desc students;3. 查看創建students表結構的語句show create table students;4. 刪除數據庫d
推薦度:
標簽: 操作 數據 數據庫
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产毛片在线 | 在线播放精品一区二区啪视频 | 精品偷自拍另类在线观看 | 久久国产精品久久久久久久久久 | 久久亚洲不卡一区二区 | 亚洲一页| 欧美一区二区高清 | 欧美一区二区三区免费高 | 热综合一本伊人久久精品 | 亚洲国产精品热久久2022 | 欧美日韩国产一区二区三区在线观看 | 亚洲精品午夜国产va久久成人 | 精品一区二区三区视频日产 | 最新国产精品亚洲二区 | 亚洲欧美另类国产 | 日韩在线视频观看 | 国产成人精品一区二区三区 | 国产一区二区免费视频 | 91香蕉国产| 北条麻妃手机在线 | xxx欧美888| 久久久xxx| 国产精品欧美韩国日本久久 | 国产精品一区久久 | 日本欧美另类 | 欧美日本一道本 | 亚洲欧洲日韩国产 | www.九九热| 一道本一区二区三区 | 久久久久久久国产精品 | 久久久精品一区二区三区 | 美女视频黄a视频全免费应用 | 黄色成人在线观看 | 亚洲色图欧美另类 | 欧美精品亚洲 | 六月丁香在线观看 | 久久久一区二区三区不卡 | 亚洲国产激情一区二区三区 | 国产乱淫a∨片免费视频 | 欧美日韩亚洲一区二区三区在线观看 | 亚洲欧美国产精品 |