日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

python mysql操作_Python的MySQL操作

發(fā)布時間:2023/12/2 数据库 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python mysql操作_Python的MySQL操作 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Python的DB-API,為大多數(shù)的數(shù)據(jù)庫實現(xiàn)了接口,使用它連接各數(shù)據(jù)庫后,就可以用相同的方式操作各數(shù)據(jù)庫。

Python DB-API使用流程:

引入API模塊。

獲取與數(shù)據(jù)庫的連接。

執(zhí)行SQL語句和存儲過程。

關(guān)閉數(shù)據(jù)庫連接。

一、安裝MySQL客戶端

MySQLdb 是用于Python鏈接Mysql數(shù)據(jù)庫的接口,它實現(xiàn)了 Python 數(shù)據(jù)庫 API 規(guī)范 V2.0,基于 MySQL C API 上建立的。

如果是windows系統(tǒng):登錄https://pypi.python.org/pypi/MySQL-python/1.2.5找到.exe結(jié)尾的包,下載安裝就好了,然后在cmd中執(zhí)行:

如果結(jié)果如上圖所示,則說明安裝成功了。

如果是Linux系統(tǒng),可以下載源碼包進行安裝,https://pypi.python.org/pypi/MySQL-python/1.2.5中下載zip包,然后安裝:

yum install –y python-devel

yum install –y mysql-devel

yum install –y gcc

unzip MySQL-python-1.2.5.zip

cd MySQL-python-1.2.5python setup.py build

python setup.py install

python>>> import MySQLdb

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

MySQLdb提供了connect方法用來和數(shù)據(jù)庫建立連接,接收數(shù)個參數(shù),返回連接對象:代碼如下:

首先在mysql的數(shù)據(jù)庫中建立python庫

create database python;

conn=MySQLdb.connect(host="192.168.203.12",user="momo",passwd="123456",db="python",charset="utf8")

比較常用的參數(shù)包括:

host:數(shù)據(jù)庫主機名.默認(rèn)是用本地主機

user:數(shù)據(jù)庫登陸名.默認(rèn)是當(dāng)前用戶

passwd:數(shù)據(jù)庫登陸的秘密.默認(rèn)為空

db:要使用的數(shù)據(jù)庫名.沒有默認(rèn)值

port:MySQL服務(wù)使用的TCP端口.默認(rèn)是3306,數(shù)字類型

charset:數(shù)據(jù)庫編碼

推薦把所有數(shù)據(jù)庫的配置寫在一個字典中,如下所示:

defconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'python','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)return cnx

三、MySQL事物

MySQL 事務(wù)主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。比如,你操作一個數(shù)據(jù)庫,公司的一個員工離職了,你要在數(shù)據(jù)庫中刪除他的資料,也要刪除該人員相關(guān)的,比如郵箱,個人資產(chǎn)等。這些數(shù)據(jù)庫操作語言就構(gòu)成了一個事務(wù)。

在MySQL中只有使用了Innodb數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù),所以很多情況下我們都使用innodb引擎。

事務(wù)處理可以用來維護數(shù)據(jù)庫的完整性,保證成批的SQL語句要么全部執(zhí)行,要么全部不執(zhí)行。

一般來說,事務(wù)是必須滿足4個條件(ACID): Atomicity(原子性)、Consistency(穩(wěn)定性)、Isolation(隔離性)、Durability(可靠性)

1、事務(wù)的原子性:一組事務(wù),要么成功;要么撤回。

2、穩(wěn)定性 : 有非法數(shù)據(jù)(外鍵約束之類),事務(wù)撤回。

3、隔離性:事務(wù)獨立運行。一個事務(wù)處理后的結(jié)果,影響了其他事務(wù),那么其他事務(wù)會撤回。事務(wù)的100%隔離,需要犧牲速度。

4、可靠性:軟、硬件崩潰后,InnoDB數(shù)據(jù)表驅(qū)動會利用日志文件重構(gòu)修改。可靠性和高速度不可兼得, innodb_flush_log_at_trx_commit選項 決定什么時候吧事務(wù)保存到日志里。

而mysql在默認(rèn)的情況下,他是把每個select,insert,update,delete等做為一個事務(wù)的,登錄mysql服務(wù)器,進入mysql,執(zhí)行以下命令:

mysql> show variables like 'auto%';+--------------------------+-------+

| Variable_name | Value |

+--------------------------+-------+

| auto_increment_increment | 1 |

| auto_increment_offset | 1 |

| autocommit | ON |

| automatic_sp_privileges | ON |

+--------------------------+-------+

4 rows in set (0.00 sec)

如上所示: 有一個參數(shù)autocommit就是自動提交的意思,每執(zhí)行一個msyql的select,insert,update等操作,就會進行自動提交。

如果把改選項關(guān)閉,我們就可以每次執(zhí)行完一次代碼就需要進行手動提交,connect對象給我們提供了兩種辦法來操作提交數(shù)據(jù)。

a)??????? mysql事務(wù)的方法

commit():提交當(dāng)前事務(wù),如果是支持事務(wù)的數(shù)據(jù)庫執(zhí)行增刪改后沒有commit則數(shù)據(jù)庫默認(rèn)回滾,白操作了

rollback():取消當(dāng)前事務(wù)

下面我們來看個例子:

我們先創(chuàng)建一個員工表:

create table employees (

emp_no intnotnull auto_increment,

emp_name varchar(16) notnull,

gender enum('M', 'F') notnull,

hire_date datenotnull,

primary key (emp_no)

);

其中,emp_no為員工id,為主鍵且唯一

emp_name為:員工的名字

fender為:性別,只有M和F兩種選擇

hire_date為:雇傭的時間。

為了試驗的效果,我們插入幾條數(shù)據(jù):

insert into employees(emp_no, emp_name, gender, hire_date) values(1001, 'lingjiang', 'M', '2015-04-01');

insert into employees(emp_no, emp_name, gender, hire_date) values(1002, 'xiang', 'M', '2015-04-01');

insert into employees(emp_no, emp_name, gender, hire_date) values(1003, 'shang', 'M', '2015-04-01');

mysql> select * fromemployees;+--------+-----------+--------+------------+

| emp_no | emp_name | gender | hire_date |

+--------+-----------+--------+------------+

| 1001 | lingjiang | M | 2015-04-01 |

| 1002 | xiang | M | 2015-04-01 |

| 1003 | shang | M | 2015-04-01 |

+--------+-----------+--------+------------+e) rowsin set (0.00 sec)

四、MySQL游標(biāo)

游標(biāo)(cursor)

游標(biāo)是系統(tǒng)為用戶開設(shè)的一個數(shù)據(jù)緩沖區(qū),存放SQL語句的執(zhí)行結(jié)果,用戶可以用SQL語句逐一從游標(biāo)中獲取記錄,并賦給主變量,交由python進一步處理,一組主變量一次只能存放一條記錄,僅使用主變量并不能完全滿足SQL語句向應(yīng)用程序輸出數(shù)據(jù)的要求。

游標(biāo)和游標(biāo)的優(yōu)點:在數(shù)據(jù)庫中,游標(biāo)是一個十分重要的概念。游標(biāo)提供了一種對從表中檢索出的數(shù)據(jù)進行操作的靈活手段,就本質(zhì)而言,游標(biāo)實際上是一種能從包括多條數(shù)據(jù)記錄的結(jié)果集中每次提取一條記錄的機制。游標(biāo)總是與一條SQL 選擇語句相關(guān)聯(lián)因為游標(biāo)由結(jié)果集(可以是零條、一條或由相關(guān)的選擇語句檢索出的多條記錄)和結(jié)果集中指向特定記錄的游標(biāo)位置組成。當(dāng)決定對結(jié)果集進行處理時,必須聲明一個指向該結(jié)果集的游標(biāo)。

常用方法:

cursor():創(chuàng)建游標(biāo)對象

close():關(guān)閉此游標(biāo)對象

fetchone():得到結(jié)果集的下一行

fetchmany([size = cursor.arraysize]):得到結(jié)果集的下幾行

fetchall():得到結(jié)果集中剩下的所有行

excute(sql[, args]):執(zhí)行一個數(shù)據(jù)庫查詢或命令

executemany (sql, args):執(zhí)行多個數(shù)據(jù)庫查詢或命令

程序例子:

1.創(chuàng)建游標(biāo)對象

import MySQLdb

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'python','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)

cus= cnx.cursor()

2.對游標(biāo)的基本操作

importMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'python','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

cus=cnx.cursor()

sql= '''select * from employees;'''

try:

cus.execute(sql)

result1=cus.fetchone()print('result1:')print(result1)

result2= cus.fetchmany(1)print('result2:')print(result2)

result3=cus.fetchall()print('result3:')print(result3) cus.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

結(jié)果:

result1:

(1001L, u'lingjiang', u'M', datetime.date(2015, 4, 1))

result2:

((1002L, u'xiang', u'M', datetime.date(2015, 4, 1)),)

result3:

((1003L, u'shang', u'M', datetime.date(2015, 4, 1)),)

解釋:

先通過MySQLdb.connect(**db_config)建立mysql連接對象

在通過 = cnx.cursor()創(chuàng)建游標(biāo)

fetchone():在最終搜索的數(shù)據(jù)中去一條數(shù)據(jù)

fetchmany(1)在接下來的數(shù)據(jù)中在去1行的數(shù)據(jù),這個數(shù)字可以自定義,定義多少就是在結(jié)果集中取多少條數(shù)據(jù)。

fetchall()是在所有的結(jié)果中搞出來所有的數(shù)據(jù)。

3.執(zhí)行多行SQL語句

#!/usr/bin/env python#-*- coding:utf-8 -*-#@Time : 2017/9/18 22:17#@Author : lingxiangxiang#@File : domon3.py

from demon2 importconnect_mysqlimportMySQLdbdefconnect_mysql():

db_config={"host": "192.168.203.12","port": 3306,"user": "momo","passwd": "123456","db": "python","charset": "utf8"}try:

cnx= MySQLdb.connect(**db_config)exceptException as e:raiseereturncnxif __name__ == "__main__":

sql= "select * from tmp;"sql1= "insert into tmp(id) value (%s);"param=[]for i in xrange(100, 130):

param.append([str(i)])print(param)

cnx=connect_mysql()

cus=cnx.cursor()print(dir(cus))try:

cus.execute(sql)

cus.executemany(sql1, param)#help(cus.executemany)

result1 =cus.fetchone()print("result1")print(result1)

result2= cus.fetchmany(3)print("result2")print(result2)

result3=cus.fetchall()print("result3")print(result3)

cus.close()

cnx.commit()exceptException as e:

cnx.rollback()raiseefinally:

cnx.close()

五、數(shù)據(jù)庫連接池

python編程中可以使用MySQLdb進行數(shù)據(jù)庫的連接及諸如查詢/插入/更新等操作,但是每次連接mysql數(shù)據(jù)庫請求時,都是獨立的去請求訪問,相當(dāng)浪費資源,而且

訪問數(shù)量達(dá)到一定數(shù)量時,對mysql的性能會產(chǎn)生較大的影響。因此,實際使用中,通常會使用數(shù)據(jù)庫的連接池技術(shù),來訪問數(shù)據(jù)庫達(dá)到資源復(fù)用的目的。

python的數(shù)據(jù)庫連接池包 DBUtils:

DBUtils是一套Python數(shù)據(jù)庫連接池包,并允許對非線程安全的數(shù)據(jù)庫接口進行線程安全包裝。DBUtils來自Webware for Python。

DBUtils提供兩種外部接口:

* PersistentDB :提供線程專用的數(shù)據(jù)庫連接,并自動管理連接。

* PooledDB :提供線程間可共享的數(shù)據(jù)庫連接,并自動管理連接。

PooledDB的參數(shù):

1. mincached,最少的空閑連接數(shù),如果空閑連接數(shù)小于這個數(shù),pool會創(chuàng)建一個新的連接

2. maxcached,最大的空閑連接數(shù),如果空閑連接數(shù)大于這個數(shù),pool會關(guān)閉空閑連接

3. maxconnections,最大的連接數(shù),

4. blocking,當(dāng)連接數(shù)達(dá)到最大的連接數(shù)時,在請求連接的時候,如果這個值是True,

請求連接的程序會一直等待,直到當(dāng)前連接數(shù)小于最大連接數(shù),如果這個值是False,會報錯,

5. maxshared 當(dāng)連接數(shù)達(dá)到這個數(shù),新請求的連接會分享已經(jīng)分配出去的連接

在uwsgi中,每個http請求都會分發(fā)給一個進程,連接池中配置的連接數(shù)都是一個進程為單位的(即上面的最大連接數(shù),都是在一個進程中的連接數(shù)),

而如果業(yè)務(wù)中,一個http請求中需要的sql連接數(shù)不是很多的話(其實大多數(shù)都只需要創(chuàng)建一個連接),配置的連接數(shù)配置都不需要太大。

連接池對性能的提升表現(xiàn)在:

1.在程序創(chuàng)建連接的時候,可以從一個空閑的連接中獲取,不需要重新初始化連接,提升獲取連接的速度

2.關(guān)閉連接的時候,把連接放回連接池,而不是真正的關(guān)閉,所以可以減少頻繁地打開和關(guān)閉連接

六、數(shù)據(jù)庫的操作

1.建表

各個表的結(jié)構(gòu)如下:

student表:

字段名

類型

是否為空

主鍵

描述

StdID

int

學(xué)生ID

StdName

varchar(100)

學(xué)生姓名

Gender

enum('M', 'F')

性別

Age

tinyint

年齡

course表:

字段名

類型

是否為空

主鍵

描述

CouID

int

課程ID

Cname

varchar(50)

課程名字

TID

int

老師ID

Score表:

字段名

類型

是否為空

主鍵

描述

SID

int

分?jǐn)?shù)ID

StdID

int

學(xué)生id

CouID

int

課程id

Grade

int

分?jǐn)?shù)

teacher表:

字段名

類型

是否為空

主鍵

描述

TID

int

老師ID

Tname

varcher(100)

老師名字

在Linux中MySQL建立student表,然后在Python代碼中執(zhí)行:

importMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'student','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

cus=cnx.cursor()#sql = '''insert into student(id, name, age, gender, score) values ('1001', 'ling', 29, 'M', 88), ('1002', 'ajing', 29, 'M', 90), ('1003', 'xiang', 33, 'M', 87);'''

student = '''create table Student(

StdID int not null,

StdName varchar(100) not null,

Gender enum('M', 'F'),

Age tinyint

)'''course= '''create table Course(

CouID int not null,

CName varchar(50) not null,

TID int not null

)'''score= '''create table Score(

SID int not null,

StdID int not null,

CID int not null,

Grade int not null

)'''teacher= '''create table Teacher(

TID int not null,

TName varchar(100) not null

)'''tmp= '''set @i := 0;

create table tmp as select (@i := @i + 1) as id from information_schema.tables limit 10;'''

try:

cus.execute(student)

cus.execute(course)

cus.execute(score)

cus.execute(thearch)

cus.execute(tmp)

cus.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

結(jié)果:

mysql> show tables;

+------------------+

| Tables_in_python |

+------------------+

| Course?????????? |

| Score??????????? |

| Student????????? |

| Teacher????????? |

| tmp????????????? |

+------------------+

1??????? rows in set (0.00 sec)

information_schema數(shù)據(jù)庫表說明:

SCHEMATA表:提供了當(dāng)前mysql實例中所有數(shù)據(jù)庫的信息。是show databases的結(jié)果取之此表。

TABLES表:提供了關(guān)于數(shù)據(jù)庫中的表的信息(包括視圖)。詳細(xì)表述了某個表屬于哪個schema,表類型,表引擎,創(chuàng)建時間等信息。是show tables from schemaname的結(jié)果取之此表。

COLUMNS表:提供了表中的列信息。詳細(xì)表述了某張表的所有列以及每個列的信息。是show columns from schemaname.tablename的結(jié)果取之此表。

STATISTICS表:提供了關(guān)于表索引的信息。是show index from schemaname.tablename的結(jié)果取之此表。

USER_PRIVILEGES(用戶權(quán)限)表:給出了關(guān)于全程權(quán)限的信息。該信息源自mysql.user授權(quán)表。是非標(biāo)準(zhǔn)表。

SCHEMA_PRIVILEGES(方案權(quán)限)表:給出了關(guān)于方案(數(shù)據(jù)庫)權(quán)限的信息。該信息來自mysql.db授權(quán)表。是非標(biāo)準(zhǔn)表。

TABLE_PRIVILEGES(表權(quán)限)表:給出了關(guān)于表權(quán)限的信息。該信息源自mysql.tables_priv授權(quán)表。是非標(biāo)準(zhǔn)表。

COLUMN_PRIVILEGES(列權(quán)限)表:給出了關(guān)于列權(quán)限的信息。該信息源自mysql.columns_priv授權(quán)表。是非標(biāo)準(zhǔn)表。

CHARACTER_SETS(字符集)表:提供了mysql實例可用字符集的信息。是SHOW CHARACTER SET結(jié)果集取之此表。

COLLATIONS表:提供了關(guān)于各字符集的對照信息。

COLLATION_CHARACTER_SET_APPLICABILITY表:指明了可用于校對的字符集。這些列等效于SHOW COLLATION的前兩個顯示字段。

TABLE_CONSTRAINTS表:描述了存在約束的表。以及表的約束類型。

KEY_COLUMN_USAGE表:描述了具有約束的鍵列。

ROUTINES表:提供了關(guān)于存儲子程序(存儲程序和函數(shù))的信息。此時,ROUTINES表不包含自定義函數(shù)(UDF)。名為“mysql.proc name”的列指明了對應(yīng)于INFORMATION_SCHEMA.ROUTINES表的mysql.proc表列。

VIEWS表:給出了關(guān)于數(shù)據(jù)庫中的視圖的信息。需要有show views權(quán)限,否則無法查看視圖信息。

TRIGGERS表:提供了關(guān)于觸發(fā)程序的信息。必須有super權(quán)限才能查看該表

而TABLES在安裝好mysql的時候,一定是有數(shù)據(jù)的,因為在初始化mysql的時候,就需要創(chuàng)建系統(tǒng)表,該表一定有數(shù)據(jù)。

set?@i?:=?0;

create?table?tmp?as?select?(@i?:=?@i?+?1)?as?id?from?information_schema.tables?limit?10;

mysql中變量不用事前申明,在用的時候直接用“@變量名”使用就可以了。set這個是mysql中設(shè)置變量的特殊用法,當(dāng)@i需要在select中使用的時候,必須加:,這樣就創(chuàng)建好了一個表tmp,查看tmp的數(shù)據(jù):

mysql> select * from tmp;

+------+

| id

|

+------+

|

1 |

|

2 |

|

3 |

|

4 |

|

5 |

|

6 |

|

7 |

|

8 |

|

9 |

|

10 |

+------+

10 rows in set (0.00 sec)

我們只是從information_schema.tables表中取10條數(shù)據(jù),任何表有10條數(shù)據(jù)也是可以的,然后把變量@i作為id列的值,分10次不斷輸出,依據(jù)最后select的結(jié)果,創(chuàng)建表tmp。

2.增加數(shù)據(jù)

substr是一個字符串函數(shù),從第二個參數(shù)1,開始取字符,取到3+ floor(rand() * 75)結(jié)束

floor函數(shù)代表的是去尾法取整數(shù)。

rand()函數(shù)代表的是從0到1取一個隨機的小數(shù)。

rand() * 75就代表的是:0到75任何一個小數(shù),

3+floor(rand() * 75)就代表的是:3到77的任意一個數(shù)字

concat()函數(shù)是一個對多個字符串拼接函數(shù)。

sha1是一個加密函數(shù),sha1(rand())對生成的0到1的一個隨機小數(shù)進行加密,轉(zhuǎn)換成字符串的形式。

concat(sha1(rand()), sha1(rand()))就代表的是:兩個0-1生成的小數(shù)加密然后進行拼接。

substr(concat(sha1(rand()), sha1(rand())), 1, floor(rand() * 80))就代表的是:從一個隨機生成的一個字符串的第一位開始取,取到(隨機3-77)位結(jié)束。

Gender字段:case floor(rand()*10) mod 2 when 1 then 'M' else 'F' end,就代表的是,

floor(rand()*10)代表0-9隨機取一個數(shù)

floor(rand()*10) mod 2 就是對0-9取得的隨機數(shù)除以2的余數(shù),

case floor(rand()*10) mod 2 when 1 then 'M' else 'F' end,代表:當(dāng)余數(shù)為1是,就取M,其他的為F

Age字段:25-floor(rand() * 5)代表的就是,25減去一個0-4的一個整數(shù)

代碼如下:

importMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'student','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

students= '''set @i := 10000;

insert into Student select @i:=@i+1, substr(concat(sha1(rand()), sha1(rand())), 1, 3 + floor(rand() * 75)), case floor(rand()*10) mod 2 when 1 then 'M' else 'F' end, 25-floor(rand() * 5) from tmp a, tmp b, tmp c, tmp d;'''course= '''set @i := 10;

insert into Course select @i:=@i+1, substr(concat(sha1(rand()), sha1(rand())), 1, 5 + floor(rand() * 40)), 1 + floor(rand() * 100) from tmp a;'''score= '''set @i := 10000;

insert into Score select @i := @i +1, floor(10001 + rand()*10000), floor(11 + rand()*10), floor(1+rand()*100) from tmp a, tmp b, tmp c, tmp d;'''theacher= '''set @i := 100;

insert into Teacher select @i:=@i+1, substr(concat(sha1(rand()), sha1(rand())), 1, 5 + floor(rand() * 80)) from tmp a, tmp b;'''

try:

cus_students=cnx.cursor()

cus_students.execute(students)

cus_students.close()

cus_course=cnx.cursor()

cus_course.execute(course)

cus_course.close()

cus_score=cnx.cursor()

cus_score.execute(score)

cus_score.close()

cus_teacher=cnx.cursor()

cus_teacher.execute(theacher)

cus_teacher.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

3.查數(shù)據(jù)

在數(shù)據(jù)庫中查出來所有名字有重復(fù)的同學(xué)的所有信息,然后寫入到文件中,代碼如下:

importcodecsimportMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'student','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

sql= '''select * from Student where StdName in (select StdName from Student group by StdName having count(1)>1 ) order by StdName;'''

try:

cus=cnx.cursor()

cus.execute(sql)

result=cus.fetchall()

with codecs.open('select.txt', 'w+') as f:for line inresult:

f.write(str(line))

f.write('\n')

cus.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

解釋:

我們先來分析一下select查詢這個語句:select * from Student where StdName in (select StdName from Student group by StdName having count(1)>1 ) order by StdName;'

我們先來看括號里面的語句:select StdName from Student group by StdName having count(1)>1;這個是把所有學(xué)生名字重復(fù)的學(xué)生都列出來,

最外面select是套了一個子查詢,學(xué)生名字是在我們()里面的查出來的學(xué)生名字,把這些學(xué)生的所有信息都列出來。

result = cus.fetchall()列出結(jié)果以后,我們通過fetchall()函數(shù)把所有的內(nèi)容都取出來,這個result是一個tuple

通過文件寫入的方式,我們把取出來的result寫入到select.txt文件中。得到最終的結(jié)果

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

刪除課程成績最差的5名老師,刪除之前要先進行查詢。代碼如下:

importcodecsimportMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'student','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

sql= '''delete from Teacher where TID in(

select TID from (select Course.CouID, Course.TID, Teacher.TName, count(Teacher.TID) as count_teacher from Course

left join Score on Score.Grade < 60 and Course.CouID = Score.CouID

left join Teacher on Course.TID = Teacher.TID

group by Course.TID

order by count_teacher desc

limit 5) as test )'''

try:

cus=cnx.cursor()

cus.execute(sql)

result=cus.fetchall()

cus.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

解釋:

先查詢出Course表中的Course.TID和Course.TID

left join 是關(guān)聯(lián)Score表,查出Score.Grade > 59,并且,課程ID和課程表的CouID要對應(yīng)上

left join Teacher 是關(guān)聯(lián)老師表,課程中的了老師ID和老師表中的老師ID對應(yīng)上

select中加上老師的名字Teacher.Tname和count(Teacher.TID)

group by Course.TID,在根據(jù)老師的的TID進行分組

oder by 最后對count_teacher進行排序,取前5行,

在通過套用一個select子查詢,把所有的TID摟出來

然后delete from Teacher 最后刪除TID在上表中的子查詢中

5.修改數(shù)據(jù)

把分?jǐn)?shù)低于5分的成績加上60分,代碼如下:

importcodecsimportMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'student','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

sql= '''select *, (grade+60) as newGrade from Score where Grade <5;'''update= '''update Score set grade = grade + 60 where grade < 5;'''

try:

cus_start=cnx.cursor()

cus_start.execute(sql)

result1=cus_start.fetchall()print(len(result1))

cus_start.close()

cus_update=cnx.cursor()

cus_update.execute(update)

cus_update.close()

cus_end=cnx.cursor()

cus_end.execute(sql)

result2=cus_end.fetchall()print(len(result2))

cus_end.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

解釋:

剛開始,我們可以查到分?jǐn)?shù)小于5分的總個數(shù)有321個

select *, (grade+60) as newGrade from Score where Grade <5;這個sql是把所有的成績小于5的都列出來,然后最后加一列分?jǐn)?shù)加60分的結(jié)果。

update Score set grade = grade + 60 where grade < 5;是把分?jǐn)?shù)小于5的所有成績都加60分

最后在檢查分?jǐn)?shù)小于5的個數(shù)為0,說明所有低于5分的分?jǐn)?shù)都發(fā)生了改變。

6.索引

MySQL索引的概念

索引是一種特殊的文件(InnoDB數(shù)據(jù)表上的索引是表空間的一個組成部分),它們包含著對數(shù)據(jù)表里所有記錄的引用指針。更通俗的說,數(shù)據(jù)庫索引好比是一本書前面的目錄,能加快數(shù)據(jù)庫的查詢速度。

索引類別

普通索引

普通索引(由關(guān)鍵字 KEY 或 INDEX 定義的索引)的唯一任務(wù)是加快對數(shù)據(jù)的訪問速度。因此,應(yīng)該只為那些最經(jīng)常出現(xiàn)在查詢條件(WHERE column =)或排序條件(ORDER BY column)中的數(shù)據(jù)列創(chuàng)建索引。只要有可能,就應(yīng)該選擇一個數(shù)據(jù)最整齊、最緊湊的數(shù)據(jù)列(如一個整數(shù)類型的數(shù)據(jù)列)來創(chuàng)建索引。

唯一索引

普通索引允許被索引的數(shù)據(jù)列包含重復(fù)的值。比如說,因為人有可能同名,所以同一個姓名在同一個“員工個人資料”數(shù)據(jù)表里可能出現(xiàn)兩次或更多次。

如果能確定某個數(shù)據(jù)列將只包含彼此各不相同的值,在為這個數(shù)據(jù)列創(chuàng)建索引的時候就應(yīng)該用關(guān)鍵字UNIQUE 把它定義為一個唯一索引。這么做的好處:一是簡化了 MySQL 對這個索引的管理工作,這個索引也因此而變得更有效率;二是 MySQL 會在有新記錄插入數(shù)據(jù)表時,自動檢查新記錄的這個字段的值是否已經(jīng)在某個記錄的這個字段里出現(xiàn)過了;如果是,MySQL 將拒絕插入那條新記錄。也就是說,唯一索引可以保證數(shù)據(jù)記錄的唯一性。事實上,在許多場合,人們創(chuàng)建唯一索引的目的往往不是為了提高訪問速度,而只是為了避免數(shù)據(jù)出現(xiàn)重復(fù)。

主索引

在前面已經(jīng)反復(fù)多次強調(diào)過:必須為主鍵字段創(chuàng)建一個索引,這個索引就是所謂的“主索引”。主索引與唯一索引的唯一區(qū)別是:前者在定義時使用的關(guān)鍵字是 PRIMARY 而不是 UNIQUE。

外鍵索引

如果為某個外鍵字段定義了一個外鍵約束條件,MySQL 就會定義一個內(nèi)部索引來幫助自己以最有效率的方式去管理和使用外鍵約束條件。

復(fù)合索引

索引可以覆蓋多個數(shù)據(jù)列,如像 INDEX (columnA, columnB) 索引。這種索引的特點是 MySQL 可以有選擇地使用一個這樣的索引。如果查詢操作只需要用到 columnA 數(shù)據(jù)列上的一個索引,就可以使用復(fù)合索引 INDEX(columnA, columnB)。不過,這種用法僅適用于在復(fù)合索引中排列在前的數(shù)據(jù)列組合。比如說,INDEX (A,B,C) 可以當(dāng)做 A 或 (A,B) 的索引來使用,但不能當(dāng)做 B、C 或 (B,C) 的索引來使用。

mysql主鍵和索引的區(qū)別:

主鍵一定是唯一性索引,唯一性索引并不一定就是主鍵。

所謂主鍵就是能夠唯一標(biāo)識表中某一行的屬性或?qū)傩越M,一個表只能有一個主鍵,但可以有多個候選索引。因為主鍵可以唯一標(biāo)識某一行記錄,所以可以確保執(zhí)行數(shù)據(jù)更新、刪除的時候不會出現(xiàn)張冠李戴的錯誤。主鍵除了上述作用外,常常與外鍵構(gòu)成參照完整性約束,防止出現(xiàn)數(shù)據(jù)不一致。數(shù)據(jù)庫在設(shè)計時,主鍵起到了很重要的作用。主鍵可以保證記錄的唯一和主鍵域非空,數(shù)據(jù)庫管理系統(tǒng)對于主鍵自動生成唯一索引,所以主鍵也是一個特殊的索引。

一個表中可以有多個唯一性索引,但只能有一個主鍵。

主鍵列不允許空值,而唯一性索引列允許空值。

索引可以提高查詢的速度。

創(chuàng)建Course的CouID的字段為主鍵?? Score的SID字段為主鍵??? Student的StdID字段為主鍵? Teacher的TID字段為主鍵,代碼如下:

importcodecsimportMySQLdbdefconnect_mysql():

db_config={'host': '192.168.203.12','port': 3306,'user': 'momo','passwd': '123456','db': 'student','charset': 'utf8'}

cnx= MySQLdb.connect(**db_config)returncnxif __name__ == '__main__':

cnx=connect_mysql()

sql1= '''alter table Teacher add primary key(TID);'''sql2= '''alter table Student add primary key(StdID);'''sql3= '''alter table Score add primary key(SID);'''sql4= '''alter table Course add primary key(CouID);'''sql5= '''alter table Score add index idx_StdID_CouID(StdID, CouID);'''

#sql6 = '''alter table Score drop index idx_StdID_CouID;''' 刪除索引

sql7 = '''explain select * from Score where StdID = 16213;'''

try:

cus=cnx.cursor()

cus.execute(sql1)

cus.close()

cus=cnx.cursor()

cus.execute(sql2)

cus.close()

cus=cnx.cursor()

cus.execute(sql3)

cus.close()

cus=cnx.cursor()

cus.execute(sql4)

cus.close()

cus=cnx.cursor()

cus.execute(sql5)

cus.close()

cus=cnx.cursor()

cus.execute(sql7)

result=cus.fetchall()print(result)

cus.close()

cnx.commit()exceptException as e:

cnx.rollback()print('error')raiseefinally:

cnx.close()

結(jié)果:

((1L, u'SIMPLE', u'Score', u'ref', u'idx_StdID_CouID', u'idx_StdID_CouID', u'4', u'const', 4L, None),)

解釋:

Sql1, sql2, sql3, sql4是添加主鍵,sql5是增加一個索引,我們也可以在mysql的客戶端上執(zhí)行sq7,得到如下的結(jié)果:

mysql> explain select * from Score where StdID = 16213;

+----+-------------+-------+------+-----------------+-----------------+---------+-------+------+-------+

| id | select_type | table | type | possible_keys?? | key???????????? | key_len | ref?? | rows | Extra |

+----+-------------+-------+------+-----------------+-----------------+---------+-------+------+-------+

|? 1 | SIMPLE????? | Score | ref? | idx_StdID_CouID | idx_StdID_CouID | 4?????? | const |??? 4 | NULL? |

+----+-------------+-------+------+-----------------+-----------------+---------+-------+------+-------+

1 row in set (0.00 sec)

這個說明,我們在搜索StdID的時候,是走了idx_StdID_CouID索引的。

總結(jié)

以上是生活随笔為你收集整理的python mysql操作_Python的MySQL操作的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

911香蕉| 国产三级香港三韩国三级 | 国产精品入口传媒 | 波多野结衣视频一区 | 久亚洲 | 99欧美视频 | 婷婷丁香五 | 日韩性xxxx| 久久久国产电影 | 天天射天天射天天射 | 国产精品免费在线播放 | 国产伦理一区二区三区 | 日韩在线观看网站 | 国产精品久久久久久妇 | 国产一区二区三区网站 | 国产精品地址 | 日韩在线三区 | 日韩精品不卡在线观看 | 97成人精品区在线播放 | 国产中年夫妇高潮精品视频 | 在线你懂 | 操操综合网 | 欧美日视频 | 国内精品久久久久影院优 | 色狠狠狠 | 丁香视频在线观看 | 91毛片在线观看 | 国产午夜精品一区二区三区在线观看 | 亚洲精品美女在线观看 | 国产精品一区二区久久精品爱微奶 | 日日夜夜噜| 亚洲v欧美v国产v在线观看 | 中国黄色一级大片 | 久久在线影院 | 美女很黄免费网站 | 婷婷综合av | 手机成人在线 | 久久精品看 | 亚洲精品66| 久久福利影视 | 97av色| 五月综合| 在线免费看黄网站 | 日韩免费二区 | 亚洲成熟女人毛片在线 | 2022久久国产露脸精品国产 | 国产精品视频线看 | 97狠狠操 | 波多野结衣在线观看视频 | japanesefreesex中国少妇 | 99精品热视频 | 欧美精品在线观看免费 | 色99色 | 黄色av电影 | 人人射人人爽 | 天天舔天天射天天操 | 国产精品igao视频网网址 | 最近字幕在线观看第一季 | 日p视频| 日本中文字幕一二区观 | 日韩在线观看你懂的 | www五月天婷婷 | 欧美精品乱码久久久久久按摩 | 日韩精品视频在线观看免费 | 激情久久五月 | 久久看片网 | 在线看免费 | 网站免费黄色 | 欧美性性网| 欧美精品一区二区在线观看 | 91在线区| 99婷婷 | 日韩视频一二三区 | 91av蜜桃| 日韩精品视频免费看 | 亚洲国产欧美一区二区三区丁香婷 | 亚洲精品乱码久久久久久9色 | 国产成人精品一区二区三区福利 | 国产小视频在线免费观看视频 | 天天操天天干天天插 | 视频二区在线视频 | 黄av资源 | 爱色av.com | 日韩在线 一区二区 | 国产玖玖在线 | 久久99精品久久只有精品 | 91亚洲精品在线观看 | a级免费观看 | 国产不卡片 | 丁香婷婷综合五月 | 日本色小说视频 | 精品久久久久久久久久久久久 | 最近中文字幕免费观看 | 91久久国产自产拍夜夜嗨 | 日韩系列在线 | 中文字幕乱码一区二区 | 在线观看国产高清视频 | 狠狠狠色丁香综合久久天下网 | 久久亚洲福利视频 | 日韩欧美精品在线 | 国产精品久久久久毛片大屁完整版 | 久久夜夜爽 | 精品毛片久久久久久 | 精品99久久久久久 | 久久黄色小说视频 | 久久精品99国产精品 | 蜜臀一区二区三区精品免费视频 | 欧美日韩高清在线观看 | 狠狠久久 | 亚洲国产日本 | 麻豆视频在线免费观看 | 免费一级片视频 | 国产精品丝袜久久久久久久不卡 | 国产亚洲精品久久 | 亚洲精品小视频在线观看 | 欧美久久久久久久久 | 国产亚洲情侣一区二区无 | 国产香蕉久久精品综合网 | 日本最新高清不卡中文字幕 | 成年人视频在线观看免费 | 免费日韩三级 | 密桃av在线 | 国产高清一区二区 | 国产色中涩 | 久久久久久毛片精品免费不卡 | 91av视频在线播放 | 激情影院在线观看 | 日韩在线理论 | 超碰免费成人 | 97电影网站 | 又黄又爽又色无遮挡免费 | 久久国产精品区 | 国产视频一区二区在线播放 | 国产精品久久久久久久久大全 | 国产午夜精品久久久久久久久久 | av不卡免费看 | 在线视频日韩欧美 | 久久精品一区二区国产 | 久久免费国产精品 | 欧美成年网站 | 久久99热精品这里久久精品 | 91伊人久久大香线蕉蜜芽人口 | 91精品国产乱码久久桃 | 高清av在线 | 福利网址在线观看 | 欧美在线视频不卡 | 国产精品久久久久久久久久久久冷 | 黄色免费大片 | 国产免费成人 | 亚洲国产中文在线 | 国产亚洲精品精品精品 | 五月天免费网站 | 日本黄色免费大片 | 国产成人精品一区二区三区网站观看 | 午夜精品一区二区国产 | 男女免费视频观看 | 综合久久久久久久 | 免费精品视频在线 | 日本精品视频网站 | 国产免费a | 中文字幕网站视频在线 | 婷五月激情 | 伊人色综合网 | 国产在线精品一区二区三区 | 国产精品久久久久永久免费 | 亚洲精品一区中文字幕乱码 | 欧美日本中文字幕 | 日本久久免费电影 | 色综合久久88色综合天天人守婷 | 久久久一本精品99久久精品66 | 综合久久久 | 丰满少妇对白在线偷拍 | 国产黑丝一区二区三区 | 久久色亚洲 | 在线观看视频黄色 | 黄色大全免费网站 | 日韩精品五月天 | 欧美精品一区二区三区一线天视频 | 99热这里只有精品久久 | 视频在线观看99 | 91精品国产91久久久久福利 | 国产精品免费视频观看 | jizz欧美性9 国产一区高清在线观看 | 欧美伦理一区 | 久久美女免费视频 | 亚洲精品免费播放 | 亚洲一区日韩精品 | 麻豆果冻剧传媒在线播放 | 四虎国产精品成人免费4hu | 国产破处精品 | 精品免费国产一区二区三区四区 | 精品av在线播放 | 夜夜操天天操 | 黄色视屏在线免费观看 | av成人在线观看 | 天天干天天弄 | 久久久久久蜜av免费网站 | 亚洲最快最全在线视频 | 丁香五月网久久综合 | 香蕉久草 | 国产精品第10页 | www色婷婷com | 四虎在线视频免费观看 | 丁五月婷婷 | 国内免费久久久久久久久久久 | 91视频网址入口 | 国产黄色大全 | 国产中文字幕在线播放 | 亚洲一区二区天堂 | 一区二区三区日韩视频在线观看 | 精品在线看 | 日本丶国产丶欧美色综合 | 在线观看av免费观看 | 福利网址在线观看 | 在线网站黄 | 在线天堂v | 亚洲黄色一级视频 | 91精品国产乱码久久桃 | 91精品视频在线看 | 久久免费视频国产 | 久久国产精品久久w女人spa | 欧美一级片免费在线观看 | 国产精品 美女 | 少妇做爰k8经典 | .精品久久久麻豆国产精品 亚洲va欧美 | 9999国产精品 | 美女视频黄在线观看 | 97国产超碰在线 | 久久呀| 亚洲成人一二三 | 欧美精品国产综合久久 | 91最新网址在线观看 | 美女视频a美女大全免费下载蜜臀 | 操操操com| 一本一道久久a久久精品 | 久久久 精品 | 黄色aa久久 | 尤物一区二区三区 | 久久撸在线视频 | 2019中文字幕网站 | 久久伊人精品一区二区三区 | 久久精品成人热国产成 | 91免费观看国产 | 91av视频| 91九色视频国产 | 国产一区二区三区高清播放 | 中文字幕精品一区 | 久久中文字幕导航 | 一区二区三区电影大全 | 日韩午夜电影网 | 欧美性受极品xxxx喷水 | 在线观看涩涩 | 成人资源在线播放 | 在线观看激情av | 亚洲国产精品免费 | 黄色大片中国 | 波多野结衣视频一区 | 中文字幕之中文字幕 | 国产精品久久久久久久久毛片 | www狠狠| 国产香蕉久久精品综合网 | 2022久久国产露脸精品国产 | 国产一级二级在线 | 91精品国产一区二区三区 | 天天干天天操av | 国产精品激情偷乱一区二区∴ | 中文字幕视频一区二区 | 亚洲资源在线观看 | 亚洲在线高清 | 免费在线观看污网站 | 夜夜视频资源 | 久久精品99国产国产 | 久久国产精品成人免费浪潮 | 天天曰视频| 中文字幕日韩伦理 | 狠狠干在线播放 | 国产精品剧情在线亚洲 | 婷婷久久五月天 | 香蕉影视 | 久久精品a | 国产系列在线观看 | 成人av资源站| 国产精品久久久久久久久费观看 | 国产粉嫩在线观看 | 超碰在线人人艹 | 久久情爱 | 99免费在线观看视频 | 97人人看 | 精品国产免费一区二区三区五区 | 九九免费精品视频 | 91麻豆精品国产91久久久久久久久 | 国产精品久久久久久超碰 | av短片在线观看 | 天天操天天干天天插 | 久草在线视频资源 | 黄色av网站在线免费观看 | 欧美日韩免费在线视频 | 一本一本久久a久久精品综合 | 国产精品中文字幕av | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 精品女同一区二区三区在线观看 | 亚洲精品色婷婷 | 爱爱av网| 欧美久久九九 | 国产伦理一区二区三区 | 狠狠色狠狠色合久久伊人 | 中文字幕日本特黄aa毛片 | 久久久久久久影视 | 黄色一级免费电影 | 久久精品视频免费观看 | 欧美亚洲三级 | 久久精品伊人 | 婷婷视频| 成人黄色片在线播放 | 夜夜视频| 人人爽人人爽人人 | 日韩在线网址 | 久久精品视频在线看 | 久久精品波多野结衣 | 视频二区在线 | 最新免费中文字幕 | 中文字幕一区在线 | 2018好看的中文在线观看 | 亚洲国产精品日韩 | 日韩三级av | 亚洲狠狠干 | 在线亚洲午夜片av大片 | 亚洲精品久久久蜜臀下载官网 | 国产美女久久久 | 国产精品第一页在线观看 | 国产精品久久久久久久免费 | 激情中文字幕 | 国产精品系列在线观看 | 在线视频一区二区 | 日韩一区二区三区观看 | 欧美人牲 | 久久久久美女 | 麻豆视频免费播放 | 国产专区视频在线观看 | 婷婷激情av | 亚洲精品日韩一区二区电影 | 在线看片中文字幕 | 成人免费在线观看入口 | 欧美精品久久久久久久久久丰满 | 亚洲国产欧洲综合997久久, | 日日色综合| 国产精品成人av电影 | 五月婷婷亚洲 | 在线中文字幕播放 | 一级黄色视屏 | 久久久国产成人 | 欧美在线观看视频免费 | 9i看片成人免费看片 | 亚洲精品在线免费看 | 九九九九九九精品 | 丁香婷婷网 | 国产 精品 资源 | 久久手机在线视频 | 亚洲另类在线视频 | 日韩网站在线 | 九九久久影视 | 五月婷婷色 | 国产免费久久av | 黄色精品一区 | 国产在线观看91 | 免费看十八岁美女 | av三级av | 成人国产精品一区二区 | 五月天.com | 2019中文 | 国产精品毛片一区视频播 | 久久综合久色欧美综合狠狠 | 久久艹人人 | 8090yy亚洲精品久久 | 日韩电影中文字幕在线观看 | 国产色婷婷精品综合在线手机播放 | av黄在线播放 | 国产精品1区2区 | 国产高清视频在线免费观看 | 免费一级片观看 | 免费99精品国产自在在线 | 亚洲成人免费在线 | 国产在线a免费观看 | 毛片3 | 成人av影院在线观看 | 有码中文字幕 | 国产老太婆免费交性大片 | www.天天综合 | 超碰电影在线观看 | 成人片在线播放 | 91视频免费看网站 | a电影免费看 | 欧美日韩国产免费视频 | 欧美成人久久 | 六月丁香六月婷婷 | 日韩在线观看三区 | 91超碰在线播放 | 中文字幕在线视频精品 | 婷婷亚洲综合五月天小说 | 成人午夜性影院 | 黄色免费视频在线观看 | 国产自偷自拍 | 在线国产视频观看 | 欧美视频在线观看免费网址 | 亚洲视频电影在线 | 看av免费网站 | 天天操夜夜操 | 久久精品日本啪啪涩涩 | 午夜性色 | 欧美另类xxxx| 韩日精品中文字幕 | 五月天亚洲婷婷 | 97网站| 日日夜夜免费精品视频 | 成人黄色小视频 | 最近更新的中文字幕 | 久久久久 | 国产日韩欧美自拍 | 91丨九色丨蝌蚪丨老版 | 国产手机免费视频 | 国产日韩精品在线 | 四虎影院在线观看av | 中文字幕在线观看第一页 | 欧美精品v国产精品v日韩精品 | 黄色网大全 | 国产丝袜 | 99久久精品久久久久久动态片 | 草莓视频在线观看免费观看 | 国产精品va视频 | 日韩黄色影院 | 人人插人人插 | 久草久视频 | 国产精品视频内 | 精品一区二区在线看 | 国产资源在线播放 | 精品美女国产在线 | 天天躁日日躁狠狠躁av麻豆 | 国产男女免费完整视频 | 免费观看的黄色片 | 国产黄 | 国产成人精品综合久久久 | 精品中文字幕在线观看 | 色婷婷av一区二 | 18性欧美xxxⅹ性满足 | 天天碰天天操视频 | 日韩精品一区二区三区第95 | 国产精品久久久久久久久久 | 911国产在线观看 | 久久在线观看视频 | 国产精品黄色在线观看 | 亚洲精品在线观看网站 | 国产我不卡 | 久久99精品国产麻豆婷婷 | 91在线公开视频 | 久久人人97超碰国产公开结果 | 操处女逼 | 日本成人黄色片 | 99国产精品久久久久老师 | 日本一区二区不卡高清 | 美女黄久久 | 在线精品视频免费播放 | 日韩中文三级 | 免费黄色在线网站 | 毛片基地黄久久久久久天堂 | 很黄很色很污的网站 | 激情婷婷综合网 | 欧美夫妻性生活电影 | 日韩黄色软件 | 中文字幕精品一区二区精品 | 久人人| 在线观看中文字幕第一页 | 精品一区二区影视 | 天天干天天操天天操 | 国产免费不卡 | 91网页版免费观看 | 天天视频色版 | 国内精品久久久久久久 | 男女免费视频观看 | 久草在线视频资源 | 日韩久久久久久久 | 日批在线看| 夜夜爽www| 成人网在线免费视频 | 日韩在线观看你懂得 | 国产在线91在线电影 | 成人在线视频你懂的 | 国产一区欧美一区 | 夜夜躁天天躁很躁波 | 亚洲最新视频在线播放 | 亚洲丝袜一区 | 久久久久国产成人免费精品免费 | 成人av在线直播 | 亚洲理论电影 | 日本韩国精品在线 | 一级黄视频 | 九九热免费精品视频 | 国产精品热 | av一级一片 | 国产精品一区在线 | 免费性网站 | 免费h视频 | 午夜精品一区二区三区视频免费看 | 九九九九热精品免费视频点播观看 | 久久国产精品精品国产色婷婷 | 欧美va天堂在线电影 | 日日干日日 | 成人在线观看影院 | 欧美一级视频在线观看 | 久久影视一区 | 天天干天天操天天搞 | 国产精品乱码久久久久久1区2区 | 黄色一级大片在线观看 | 精品国自产在线观看 | 欧美一二在线 | 一区在线免费观看 | 一区二区三区四区五区在线 | 在线观看日韩中文字幕 | 午夜av在线电影 | 国产精品久久久久久久久久久久午 | 天天操天天干天天爱 | 欧美 亚洲 另类 激情 另类 | a级免费观看 | 色综合 久久精品 | 国产精品久久一区二区三区, | 久草青青在线观看 | 色婷婷中文| 一级黄色片在线播放 | 色网站在线 | 在线视频麻豆 | 国产不卡在线观看视频 | 欧美日韩另类在线 | 国产精品入口66mio女同 | 在线视频观看成人 | 亚洲精品中文字幕在线 | 国产日韩欧美在线 | 久操视频在线观看 | 亚洲国产视频在线 | 国产精品久久久久久久7电影 | 久久香蕉电影网 | 美女视频黄免费网站 | 天天干天天操人体 | 国产亚洲精品免费 | 91视频麻豆视频 | 久久a v电影 | 免费av黄色 | 一区二区在线不卡 | 欧美xxxxx在线视频 | 亚洲成av人影片在线观看 | 91精品国产乱码久久桃 | 中文字幕欧美日韩va免费视频 | 欧美激情精品一区 | 国产精品九九久久久久久久 | 亚洲天堂色婷婷 | 特黄免费av | 色婷婷激情电影 | 天天操天天干天天爱 | 成人久久久久久久久久 | www在线观看国产 | 91精品久久久久久久99蜜桃 | 一区二区精品视频 | 国产日本在线 | 国产高清在线视频 | 国产九九九视频 | 久久久免费高清视频 | 国产高清亚洲 | 欧美aaa视频| 久久免费视频国产 | 91粉色视频 | 一区二区三区在线不卡 | av理论电影 | 国产精品久久久久久久久久99 | 欧美激情视频一区二区三区免费 | 91大神精品视频在线观看 | 日韩成人在线一区二区 | 亚洲精品国产精品国自产 | 国产在线色视频 | 亚洲欧美国内爽妇网 | 免费99精品国产自在在线 | 国产午夜激情视频 | 国产黄a三级三级三级三级三级 | 99爱这里只有精品 | 国产成人一区二区三区在线观看 | 国产一级淫片在线观看 | 91在线视频免费91 | 午夜丰满寂寞少妇精品 | 黄色av电影在线 | 久久伊人爱 | 欧美另类激情 | 91麻豆免费版| 在线观看www视频 | 亚洲精品欧洲精品 | 爱爱av网站| 日韩精品高清视频 | 日本99热 | 偷拍福利视频一区二区三区 | 91女子私密保健养生少妇 | 久草av在线播放 | 精品免费99久久 | 狠狠成人 | 国产福利91精品张津瑜 | 啪嗒啪嗒免费观看完整版 | av成年人电影 | 久久撸在线视频 | 久久久久综合网 | 五月综合色 | 亚洲日b视频 | 国内精品久久久久久久影视简单 | 9999毛片| 97在线观视频免费观看 | 日本在线视频一区二区三区 | 亚洲黄色免费电影 | 日本韩国欧美在线观看 | 日韩免费在线观看网站 | 免费日韩视 | 天天躁日日躁狠狠躁 | 成人久久亚洲 | www.com黄 | 国产乱老熟视频网88av | 中文字幕专区高清在线观看 | 午夜资源站 | 成人午夜剧场在线观看 | 麻豆一精品传二传媒短视频 | 国产精品久久久久久久久久久久 | 国产欧美久久久精品影院 | 亚洲午夜精品久久久 | 久久av免费| a在线免费观看视频 | 亚洲国产中文字幕 | 久草免费资源 | 亚洲第一香蕉视频 | 在线视频精品播放 | 精品一区二区综合 | 99久久毛片 | 国产精品久久婷婷六月丁香 | av爱干| 久草在线欧美 | 亚洲视频精品 | 天天综合在线观看 | 日韩精品欧美视频 | 国产手机视频在线播放 | 日韩中文字幕在线不卡 | 成人免费视频播放 | 欧美一二在线 | 国产99精品在线观看 | 久久久影片 | 又色又爽又黄 | 日韩 在线a | 成人午夜在线观看 | 91成人短视频在线观看 | 欧美日韩一区二区三区免费视频 | 中文字幕第一页av | 亚洲精品国产精品乱码不99热 | 国产精品6 | 91久久久久久久 | 欧美一区二区三区四区夜夜大片 | 日日夜夜免费精品 | 黄色在线成人 | 成人免费观看完整版电影 | 国产成人一区二区三区在线观看 | 欧洲精品一区二区 | 国产精品久久久久久久久久久久久 | 粉嫩av一区二区三区四区五区 | 国产精品福利在线 | 国模视频一区二区三区 | 亚洲综合五月 | 黄色www| av资源中文字幕 | 亚洲激情免费 | 日韩精品久久久 | 亚洲精品午夜久久久久久久 | 国产亚洲综合精品 | 久久影院午夜论 | 在线观看aaa | 欧美日韩精品久久久 | 亚洲精品视频在线观看免费视频 | 日韩欧美高清一区二区三区 | 日韩在线电影一区 | 午夜影院日本 | 免费观看日韩 | 天天干天天操天天射 | 人人澡人人爽 | 深夜免费福利视频 | 午夜视频免费播放 | 精品久久国产精品 | 成人小电影在线看 | 亚洲天堂免费视频 | 在线亚洲观看 | 亚洲视频1 | 亚洲片在线 | 久久综合综合久久综合 | 精品1区2区 | 人人草在线观看 | 亚洲欧洲中文日韩久久av乱码 | 丁香五月网久久综合 | 亚洲欧美日韩国产一区二区 | 精品影院| 久操视频在线播放 | 久久婷婷激情 | 伊人欧美 | 狠狠躁夜夜躁人人爽视频 | 欧美一进一出抽搐大尺度视频 | 久久久久一区二区三区 | 精品国产黄色片 | 波多野结衣电影一区二区三区 | 欧美aa一级| 97在线看 | 久久黄色美女 | 国产精品久久久777 成人手机在线视频 | 91丨九色丨国产在线观看 | 国产色一区 | 日韩va亚洲va欧美va久久 | 一 级 黄 色 片免费看的 | 国产精品综合在线观看 | 97香蕉超级碰碰久久免费软件 | 国产精品原创 | 国产精品av在线 | 国产福利在线 | 在线看成人片 | av电影一区二区 | 亚洲精品黄色 | 又黄又爽又无遮挡的视频 | 青草视频在线播放 | 亚洲精品白浆高清久久久久久 | 欧美性猛片, | 色综合天天 | 欧美黄污视频 | 国产91免费在线 | 色在线视频 | 国产中出在线观看 | 久久影院精品 | 午夜视频在线观看一区二区三区 | 国产真实精品久久二三区 | 色黄www小说 | 国产黄色一级片在线 | 午夜精品福利在线 | 狠狠地日| 97国产大学生情侣白嫩酒店 | 久久久婷 | 日韩在线影视 | 成人激情开心网 | 日韩电影在线一区 | 日韩和的一区二在线 | 欧美精品中文 | 日韩电影一区二区在线 | 中文字幕一区二区三区在线播放 | 亚洲国产成人精品在线 | 久久九九精品久久 | 久久国产成人午夜av影院宅 | 91精品国产福利在线观看 | 天天操天天干天天摸 | 四虎国产视频 | 国产在线高清视频 | 国产精品99爱 | av免费看av| 免费瑟瑟网站 | 久草99 | 国产女教师精品久久av | 久草视频视频在线播放 | 韩国av电影在线观看 | 丁香五月缴情综合网 | 在线观看成年人 | 一区 二区 精品 | 色 免费观看 | 国产精品久久99综合免费观看尤物 | 亚洲精品国产第一综合99久久 | 久久99精品久久久久久久久久久久 | 日韩城人在线 | 九月婷婷人人澡人人添人人爽 | 免费高清在线观看成人 | 久草国产在线观看 | 五月婷婷播播 | 久久99热久久99精品 | 91探花国产综合在线精品 | 国内精品久久久久影院日本资源 | 国产福利一区二区三区在线观看 | avhd高清在线谜片 | 国产精品久久久久久久久婷婷 | 欧美极品xxx | www五月婷婷| 精品国产一区二区三区四区在线观看 | 久久久久伊人 | 波多野结衣久久资源 | 亚洲一级电影 | 精品欧美一区二区在线观看 | 美女视频黄频大全免费 | 999久久久久久久久久久 | 久久a v电影 | 久久国产99 | 91九色成人| 免费日韩 精品中文字幕视频在线 | 天天干天天操天天干 | 久久国产精品久久国产精品 | 欧美午夜精品久久久久 | 天天干天天草天天爽 | 国产 欧美 日产久久 | 免费一级毛毛片 | 97精品超碰一区二区三区 | 国产精品第54页 | 欧美aaa视频 | 成人av手机在线 | 日韩中文字幕在线 | 精品一二三四视频 | 亚洲天堂精品视频在线观看 | 午夜精品福利一区二区三区蜜桃 | 成人免费视频免费观看 | 狠狠躁天天躁综合网 | 欧美日韩在线电影 | 久久视屏网 | 五月天欧美精品 | 69精品久久久 | 亚洲做受高潮欧美裸体 | 国产精品久久久久永久免费观看 | 天天草天天色 | 91精品在线视频观看 | 高清av中文在线字幕观看1 | 日韩av网址在线 | 久久久麻豆精品一区二区 | 欧美一区二区三区在线 | 免费开视频 | 色偷偷97 | 丁香花五月 | 国产亚洲婷婷免费 | av中文字幕日韩 | 亚洲黄色一级大片 | www国产亚洲精品久久麻豆 | 精品久久久久亚洲 | 免费在线成人 | 黄色电影网站在线观看 | 欧美性色综合网站 | 缴情综合网五月天 | 91高清完整版在线观看 | 色网站免费在线看 | 麻豆视频在线播放 | 韩日电影在线观看 | 日韩高清av | 999久久国产精品免费观看网站 | 亚洲激情影院 | 91看片在线看片 | 免费国产黄线在线观看视频 | 婷婷在线不卡 | 天天av综合网 | www四虎影院 | 日韩精品久久一区二区三区 | 激情婷婷色 | 亚洲国产电影在线观看 | 亚洲精品99久久久久中文字幕 | 在线观看一区视频 | 一区二区精品在线视频 | 国产va精品免费观看 | 亚洲日本激情 | 91黄视频在线 | 欧美成a人片在线观看久 | 免费看的黄色的网站 | 国产高清在线看 | 午夜精品久久久久久99热明星 | 国产亚洲激情视频在线 | 久久五月婷婷丁香社区 | 少妇bbb搡bbbb搡bbbb | 国产不卡在线看 | 毛片无卡免费无播放器 | 91精品视频导航 | 婷婷综合国产 | 精品一区二区在线免费观看 | 黄av资源 | 蜜臀久久99精品久久久酒店新书 | 久草视频2| 麻豆视频免费在线观看 | 日韩在线视频一区 | 久久成人一区二区 | 99免费在线视频 | 日韩在线观看视频在线 | 亚洲欧洲精品一区二区 | 美女av在线免费 | 天天插一插 | 五月综合激情 | 国产精品久久久久久久久久东京 | 久久电影国产免费久久电影 | 免费a网址| 久久国产三级 | 国产麻豆视频免费观看 | 国产日韩欧美自拍 | 激情动态 | 成人久久18免费网站图片 | 日韩有码在线播放 | 国产一区二区三区高清播放 | 久久影院精品 | 91丝袜美腿 | 美女视频黄色免费 | 色www.| 天天射日 | av短片在线观看 | 伊人色播| 亚洲高清91 | 成人黄视频| 日日爽天天 | 国产午夜精品久久久久久久久久 | 国产精品福利午夜在线观看 | 久久影视精品 | 免费看色网站 | 亚洲综合成人av | 久久精品中文字幕一区二区三区 | 免费国产一区二区 | 亚州欧美视频 | 夜添久久精品亚洲国产精品 | 国产精彩视频一区二区 | 亚洲精品乱码久久久久久久久久 | 日韩欧美一区视频 | 亚洲最大在线视频 | 免费看黄在线网站 | 国产色视频123区 | 97超碰香蕉 | 91九色蝌蚪| 久久综合成人网 | 中文字幕一区二区三区四区久久 | 亚洲精品国偷自产在线99热 | 麻豆影视在线免费观看 | 日韩一二三区不卡 | 999久久久免费视频 午夜国产在线观看 | 久久久精品国产一区二区三区 | 亚洲无吗视频在线 | 蜜臀aⅴ国产精品久久久国产 | 色综合欧洲 | 98久久 | 色欲综合视频天天天 | 999成人国产 | 欧美 日韩 视频 | 日韩在线观看一区 | ,久久福利影视 | 香蕉视频免费在线播放 | 亚洲干 | 久久免费99精品久久久久久 | 欧美一二在线 | 天天草天天干 | 精品国产一区二区三区久久久 | 中文字幕丝袜一区二区 | 91视频最新网址 | 久草在线观看视频免费 | 久久久久亚洲天堂 | 99久久er热在这里只有精品15 | 亚洲一区二区高潮无套美女 | 97视频在线观看免费 | 中文字幕日韩免费视频 | 黄色免费视频在线观看 | 久久综合操| 在线观看日韩国产 | 91在线资源 | 人人精久 | 婷婷综合av| 久久蜜臀一区二区三区av | 欧美一级电影在线观看 | 国产精品久久久久永久免费观看 | 国产精品久久一区二区三区不卡 | 久久综合精品国产一区二区三区 | 91在线看免费 | 天天躁天天狠天天透 | 欧美analxxxx | 亚洲视频第一页 | 亚洲年轻女教师毛茸茸 | 女人高潮特级毛片 | 免费a视频| 国产字幕在线播放 | 久久精品视频观看 | 99视频免费看 | 国产乱码精品一区二区蜜臀 | 91看片在线看片 | 欧美成人h版电影 | 国产精品成人av电影 | 久久综合九色综合97_ 久久久 | av免费网页 | 一级性av| 91精品在线观看入口 | 福利二区视频 | 精品久久久久久综合日本 | 欧美高清成人 | 婷婷网址 | av免费在线播放 | 91精品免费在线 | 国产69久久| 中文字幕av有码 | 午夜精品久久久久久久99 | 91亚洲精品久久久蜜桃网站 | 亚洲视频2| 99热播精品 | 500部大龄熟乱视频使用方法 | 西西444www大胆高清视频 | 免费黄a大片 | 亚洲综合色婷婷 | www操操 | 成人在线一区二区三区 | av在线永久免费观看 | 国产久草在线观看 | 亚洲精品一区二区18漫画 | 日本中文字幕在线一区 | 欧美日韩超碰 | 久草视频一区 | www.97视频 | 久久精品直播 | 精品在线不卡 |