亚洲成人一区在线观看_天堂网www_国产精品久久9_中文在线播放_伊人天天_久久精品久久久精品美女

當前位置:首頁 > 網(wǎng)站舊欄目 > 學習園地 > 設計軟件教程 > 翻譯www.djangobook.com之第五章:與數(shù)據(jù)庫交互:模型

翻譯www.djangobook.com之第五章:與數(shù)據(jù)庫交互:模型
2010-01-13 23:36:18  作者:  來源:
第3章我們談到了用Django構建動態(tài)網(wǎng)站,設置視圖和URL配置
如我們所說,試圖負責邏輯和返回應答,例子中我們計算了當前的日期和時間
現(xiàn)在的Web程序中常常和數(shù)據(jù)庫打交道
一個數(shù)據(jù)庫驅(qū)動的網(wǎng)站在后臺連接數(shù)據(jù)庫服務器,得到并顯示很好的格式化的Web頁面
同樣,網(wǎng)站也可以提供給訪問者也具有操作數(shù)據(jù)庫的功能
許多復雜的網(wǎng)站以上兩種功能的結合,如Amazon.com就是一個數(shù)據(jù)庫驅(qū)動的站點
每一個產(chǎn)品頁面都是Amazon數(shù)據(jù)庫格式后的HTML,你訪問頁面也就是間接訪問數(shù)據(jù)庫
Django很適合數(shù)據(jù)庫驅(qū)動的網(wǎng)站,通過Python它提供強大的數(shù)據(jù)庫訪問能力
這章將講述Django的數(shù)據(jù)庫層

在視圖里進行數(shù)據(jù)庫查詢的“啞”方式
前一章講到通過在視圖里硬編碼HTML來輸出HTML的“啞”方式,在視圖里也有得到數(shù)據(jù)庫數(shù)據(jù)的“啞”方式
這很簡單,只是使用一些Python庫執(zhí)行SQL查詢并且處理結果
在下面的例子里我們使用MySQLdb庫(可以在如下地址得到http://sourceforge.net/projects/mysql-python)
來連接MySQL數(shù)據(jù)庫,得到一些記錄來填充模板,并顯示到Web頁面上:
Java代碼 復制代碼
  1. from django.shortcuts import render_to_response   
  2. import MySQLdb   
  3.   
  4. def book_list(request):   
  5.     db = MySQLdb.connect(user='me', db='mydb', passwd='secret', host='localhost')   
  6.     cursor = db.cursor()   
  7.     cursor.execute('SELECT name FROM books ORDER BY name')   
  8.     names = [row[0for row in cursor.fetchall()]   
  9.     db.close()   
  10.     return render_to_response('book_list.html', {'names': names})  

這個方法可以工作,但是馬上一些問題出來了:
1,我們把數(shù)據(jù)庫連接的參數(shù)硬編碼到代碼里面了,理想狀況下它們應該存儲在Django配置里面
2,我們必須寫一些樣板文件代碼,如建立連接,創(chuàng)建cursor,執(zhí)行語句和關閉連接等
細想狀況下,我們應該只需指出我們需要什么結果
3,它把我們和MySQL綁在一起,如果我們想切換到PostgreSQL
我們必須使用不同的數(shù)據(jù)庫適配器psycopg,改變數(shù)據(jù)庫連接參數(shù)以及考慮重寫SQL語句
理想狀況下數(shù)據(jù)庫服務器應該是抽象的,替換數(shù)據(jù)庫應該只在一個地方設置
你可能會想,Django的數(shù)據(jù)庫層的目標應該是解決這些問題,下面簡單看看怎樣用Django數(shù)據(jù)庫API重寫上面代碼:
Java代碼 復制代碼
  1. from django.shortcuts import render_to_response   
  2. from mysite.books.models import Book   
  3.   
  4. def book_list(request):   
  5.     books = Book.objects.order_by('name')   
  6.     return render_to_response('book_list.html', {'books': books})  

我們在本章稍后解釋這些代碼,現(xiàn)在先感覺一下它的樣子

MTV開發(fā)模式
在我們專研更多的代碼之前,讓我們先花點時間考慮一些Django Web程序的整體設計
前面的章節(jié)我們提到,Django設計來鼓勵松耦合和分離程序模塊
如果你遵循這個哲學,改變一部分代碼而不影響其它模塊是很容易做到的
例如在視圖方法里,我們討論了使用模板來分離業(yè)務邏輯和呈現(xiàn)邏輯的重要性
在數(shù)據(jù)庫層的數(shù)據(jù)訪問邏輯我們將遵循同樣的哲學
數(shù)據(jù)訪問,業(yè)務邏輯和呈現(xiàn)邏輯組成常說的“Model View Controller”(MVC)軟件架構模式
“Model”指數(shù)據(jù)訪問層,“View”指系統(tǒng)中選擇什么來呈現(xiàn)以及怎樣呈現(xiàn)的部分
“Controller”則指系統(tǒng)中通過用戶輸入決定使用哪個視圖及訪問必要的模型的部分
采用MVC,MTV等縮寫只是便于開發(fā)人員溝通
Django遵循了MVC模式,它可以被稱位MVC框架,下面是M,V,C在Django中的位置:
1,M,數(shù)據(jù)據(jù)訪問部分,通過Django的數(shù)據(jù)庫層處理,也就是本章所講述的內(nèi)容
2,V,選擇數(shù)據(jù)并決定怎樣呈現(xiàn)的部分,通過視圖和模板來處理
3,C,控制部分通過Django框架本身的URL配置和對Python方法的調(diào)用來處理
因為“C”是Django框架本身處理而導致Django大部分精彩的東西在于模型,模板和視圖
所以Django被稱位MTV框架:
1,M,代表模型,是數(shù)據(jù)訪問層,它包含了關于數(shù)據(jù)的一切東西,怎樣得到數(shù)據(jù),怎樣驗證數(shù)據(jù),
它具有什么行為以及數(shù)據(jù)之間的關系
2,T,代表模板,是展現(xiàn)層,它包含了呈現(xiàn)相關的決策,如內(nèi)容怎樣在Web頁面中顯示以及其它類型的文檔
3,V,代表視圖,是業(yè)務邏輯層,它包含了訪問模型的邏輯和選擇合適的模板
你可以認為視圖是模型和模板的橋梁
如果你對MVC框架熟悉,如Ruby on Rails,你可以把Django的視圖想象成“controllers”,
把Django的模板想象成“views”,這是對MVC的不同解釋造成的不幸的混亂
在Django關于MVC的解釋中,“view”描述呈現(xiàn)給用戶的數(shù)據(jù)
沒有必要弄清數(shù)據(jù)怎樣顯示,而是描述哪個數(shù)據(jù)應該被呈現(xiàn)
對比而言,Ruby on Rails以及類似的框架建議controller的工作包括決定哪個數(shù)據(jù)顯示給用戶,
視圖嚴格的決定數(shù)據(jù)怎樣顯示,而不是決定哪個數(shù)據(jù)來顯示
每一個解釋都不比另一個正確,最重要的事情是理解底層的概念

配置數(shù)據(jù)庫
所有的哲學牢記在心之后,讓我們開始發(fā)掘Django的數(shù)據(jù)庫層
首先我們注意一些細小的配置,我們需要告訴Django使用哪個數(shù)據(jù)庫和怎樣連接它
我們假設你已經(jīng)有了一個數(shù)據(jù)庫服務器,啟動它并創(chuàng)建一個database(使用CREATE DATABASE語句)
SQLite是一個特例,不需要創(chuàng)建database,因為SQLite在文件系統(tǒng)上使用單獨的文件存儲數(shù)據(jù)
和上一章的TEMPLATE_DIRS一樣,數(shù)據(jù)庫配置在Django配置文件里面,默認是settings.py
Java代碼 復制代碼
  1. DATABASE_ENGINE = ''  
  2. DATABASE_NAME = ''  
  3. DATABASE_USER = ''  
  4. DATABASE_PASSWORD = ''  
  5. DATABASE_HOST = ''  
  6. DATABASE_PORT = ''  

我們來看看每個配置是什么意思:
1,DATABASE_ENGINE告訴Django使用哪個數(shù)據(jù)庫引擎,如果你使用數(shù)據(jù)庫和Django工作的話,
DATABASE_ENGINE必須是下面的字符串集合:
引用

設置                         數(shù)據(jù)庫               需要的適配器
postgresql             PostgreSQL       psycopg version 1.x, http://initd.org/projects/psycopg1

postgresql_psycopg2    PostgreSQL       psycopg version 2.x, http://initd.org/projects/psycopg2

mysql                  MySQL            MySQLdb, http://sourceforge.net/projects/mysql-python

sqlite3                SQLite No adapter needed if using Python 2.5+ Otherwise, pysqlite, http://initd.org/tracker/pysqlite

ado_mssql        Microsoft SQL Server   adodbapi version 2.0.1+, http://adodbapi.sourceforge.net/

oracle                 Oracle           cx_Oracle, http://www.python.net/crew/atuining/cx_Oracle/
 

注意不管你使用什么數(shù)據(jù)庫,你都需要安裝相應的數(shù)據(jù)庫適配器,每個適配器在網(wǎng)上都是免費的
2,DATABASE_NAME告訴Django數(shù)據(jù)庫名字是什么,如果你使用SQLite,
指出數(shù)據(jù)庫文件的完整的文件系統(tǒng)路徑,如'/home/django/mydata.db'
3,DATABASE_USER告訴Django你連接數(shù)據(jù)庫的用戶名,如果你使用SQLite,這項為空
4,DATABASE_PASSWORD告訴Django你連接數(shù)據(jù)庫的密碼,如果你使用SQLite或者你的密碼為空,則這項為空
5,DATABASE_HOST告訴Django你連接數(shù)據(jù)庫的主機,如果你的數(shù)據(jù)庫和Django安裝在同一臺計算機上,則這項為空
如果你使用SQLite,這項為空
MySQL在這里很特殊,如果這項的值以'/'開頭并且你使用MySQL,MySQL會通過Unix socket連接特殊的socket
例如DATABASE_HOST = '/var/run/mysql/'
如果你使用MySQL但這項的值不是以'/'開頭,那么這項的值就假設為所連接的主機
6,DATABASE_PORT告訴Django連接數(shù)據(jù)庫的端口,如果你使用SQLite,則這項為空
否則,如果這項為空,底層的數(shù)據(jù)庫適配器會使用給的數(shù)據(jù)庫的默認端口
大部分情況下默認端口即可
一旦你輸入了這項設置,測試一下你的配置
首先在你第2章創(chuàng)建的mysite項目目錄下運行python manage.py shell
你將會看到進入了Python交互環(huán)境,但是眼睛是會騙人的!
它和普通的python有一個重要的不同,普通的python命令進入的是Python shell,
但是前者告訴Django在啟動shell前使用哪個settings文件
這是做數(shù)據(jù)庫查詢的主要前提,Django需要知道使用哪個settings文件來得到數(shù)據(jù)庫連接信息
在后臺,python manage.py shell設置了DJANGO_SETTINGS_MODULE環(huán)境變量
后面我們會解釋它的微妙之處,先讓我們測試一下數(shù)據(jù)庫配置:
>>> from django.db import connnection
>>> cursor = connection.cursor()
如果什么事情都沒有發(fā)生,則你的數(shù)據(jù)庫配置對了
否則,檢查錯誤信息作為線索,看看哪里出錯了,下面是一些常見的錯誤:
Java代碼 復制代碼
  1. 錯誤信息                                                    解決方法    
  2. You haven’t set the DATABASE_ENGINE setting yet.   
  3. 設置DATABASE_ENGINE而不是為空   
  4.   
  5. Environment variable DJANGO_SETTINGS_MODULE is undefined.   
  6. 運行command python manage.py shell而不是python   
  7.   
  8. Error loading __ module: No module named __.   
  9. 你還沒有安裝數(shù)據(jù)庫相關的適配器(如psycopg或MySQLdb)   
  10.   
  11. __ isn’t an available database backend.   
  12. 將你的DATABASE_ENGINE設置為合法的數(shù)據(jù)庫引擎,你是不是敲錯字母了?   
  13.   
  14. database __ does not exist   
  15. 更改DATABASE_NAME指向一個存在的數(shù)據(jù)庫,或者執(zhí)行CREATE DATABASE語句來創(chuàng)建它   
  16.   
  17. role __ does not exist   
  18. 更改DATABASE_USER指向一個存在的user,或者在數(shù)據(jù)庫中創(chuàng)建一個user   
  19.   
  20. could not connect to server   
  21. 確認DATABASE_HOST和DATABASE_PORT設置正確,以及確認數(shù)據(jù)庫正在運行  


你的第一個app
既然你驗證了數(shù)據(jù)庫連接正確,現(xiàn)在就來創(chuàng)建一個Django app
Django app是一些Django代碼,包括模型和視圖,它們在同一個Python包下面,代表了一個完整的Django程序
在這里值得解釋一下術語,因為這容易使初學者弄糊涂
我們第2章已經(jīng)創(chuàng)建了一個project,那么project和app的區(qū)別是什么呢?區(qū)別就是配置和代碼:
1,一個project是許多Django app的集合的實例,加上那些app的的配置
技術上來說,一個project唯一的前提是它提供一個settings文件,里面定義了數(shù)據(jù)庫連接信息,
安裝的app,TEMPLATE_DIRS等等
2,一個app是Django的可移動功能集,通常包括模型和視圖,存在于一個單獨的Python包里面
例如,Django含有幾個app,如commenting系統(tǒng)和自動的admin界面
關鍵要注意的是它們是可移動并且可以在不同的project重用
沒有嚴格的規(guī)定怎樣安排和計劃你的Django代碼,它是很靈活的
如果你在構建一個單獨的網(wǎng)站,你可能只使用一個app
如果你在構建一個復雜的站點,你可能想把它分成幾個app,這樣你就可以在以后分別重用他們
在前面我們的例子中證明我們確實根本不需要創(chuàng)建app,我們只是創(chuàng)建了一個viws.py文件
然后在里面寫視圖方法并設置我們的URL配置指向這些方法,我們不需要“apps”
但是,有一點需要重視app慣例,如果你使用Django的數(shù)據(jù)庫層(模型),你必須創(chuàng)建Django app
模型必須存在于app,所以為了開始寫模型,我們將創(chuàng)建一個新的app
在前面創(chuàng)建的mysite目錄下面,運行下面的命令來創(chuàng)建一個新的app:
python manage.py startapp books
這個命令不會造成任何輸出,但它在mysite目錄下創(chuàng)建了一個books目錄,讓我們看看它的內(nèi)容:
books/
    __init__.py
    models.py
    views.py
這些文件將包含這個app的模型和視圖
用你最喜歡的文本編輯器看看models.py和views.py,它們都是空的,除了models.py里一個import
這是你的Django app的空白區(qū)

用Python定義模型
我們前面討論到,MTV中的M代表模型
一個Django模型用Python代碼描述了你的數(shù)據(jù)庫中的數(shù)據(jù)
它是你的數(shù)據(jù)結構,相當于SQL的CREATE TABLE語句,除了在Python中它比數(shù)據(jù)庫定義包含的內(nèi)容更多
Django在后臺使用模型來執(zhí)行SQL代碼并返回方便的Python數(shù)據(jù)結構來表示你的數(shù)據(jù)庫表的行
Django也使用模型來描述一些高級概念,這些SQL是做不到的
如果你對數(shù)據(jù)庫很熟悉,你可能馬上會想到既在Python中又在SQL中定義數(shù)據(jù)模型豈不是很多余?
Django采用這種工作方式有幾個原因:
1,自省要求過度并且不完美
為了提供方便的數(shù)據(jù)訪問API,Django需要知道數(shù)據(jù)庫結構,有兩種方式達到這個目標
一是在Python里顯式的描述數(shù)據(jù),一是運行時內(nèi)省數(shù)據(jù)庫來決定數(shù)據(jù)模型
第二種方式看起來更干凈,因為表的元數(shù)據(jù)僅僅存在于一個地方,但這會導致幾個問題
第一,運行時內(nèi)省數(shù)據(jù)庫顯然要求過度
如果每次Web請求都需要內(nèi)省數(shù)據(jù)庫,即使Web服務器已經(jīng)初始化,這也會導致的過度的等級不可接受
(有些人認為這個過度的等級可以接受,但Django的開發(fā)者目標是打敗盡可能多的過度框架,
所以這個方案使Django成功的在速度上快于其它的高級框架)第二,一些數(shù)據(jù)庫特別是舊版本的MySQL
并不把足夠的元數(shù)據(jù)存儲起來,所以就導致不能進行準確和完整的自省
2,寫Python代碼是快樂的,保持所有的事情用Python來做可以減少你大腦作切換的時間
如果你保持一個單獨的開發(fā)環(huán)境和心智盡可能久,它將是你非常的高效
寫SQL,然后Python,然后又SQL是很令人心煩的
3,讓數(shù)據(jù)模型存儲在代碼里而不是你的數(shù)據(jù)庫會使你更容易控制你的模型版本
這樣你可以很輕松的跟蹤你的數(shù)據(jù)的更改
4,SQL僅僅允許關于數(shù)據(jù)結構的某一級別的元數(shù)據(jù)
例如,大部分數(shù)據(jù)庫系統(tǒng)并不提供專門的數(shù)據(jù)類型來支持e-mail地址或者url
Django模型則可以,高級數(shù)據(jù)類型的優(yōu)點是更高的生產(chǎn)率和更易重用的代碼
5,SQL在不同的數(shù)據(jù)庫平臺不一致,例如,如果你正在發(fā)布你一個Web程序
發(fā)布一個Python模塊來描述數(shù)據(jù)結構會比分開為MySQL,PostgreSQL和SQLite寫CREATE TABLE語句更高效
盡管如此,這個方法的一個缺點是Python代碼所做的事情可能超出實際上數(shù)據(jù)庫里的數(shù)據(jù)的范圍
如果你更改了Django模型,你需要在你的數(shù)據(jù)庫做同樣的改動做保持數(shù)據(jù)庫和模型一致
本章后面我們將詳細解釋解決此問題的策略
最后,我們必須指出的是Django包含了一個輔助工具來通過現(xiàn)存的數(shù)據(jù)庫生成模型
這對于迅速接管和運行遺留數(shù)據(jù)很有幫助

你的第一個模型
這一章我們將關注book/author/publisher數(shù)據(jù)結構,它們是眾所周知的
我們將支持一下概念,域和關系:
1,一個author有一個salutation(如Mr.或Mrs.),一個first name,一個last name,一個e-mail地址和一個頭像photo
2,一個publisher有一個name,一個street地址,一個city,一個state/province,一個country和一個Web site
3,一個book有一個title和一個publication date,一個或多個authors(many-to-many),一個單獨的publisher(one-to-many)
在Django中第一步是使用Python代碼描述上面的數(shù)據(jù)庫結構,在startapp命令創(chuàng)建的models.py中輸入下面的內(nèi)容:
Java代碼 復制代碼
  1. from django.db import models   
  2.   
  3. class Publisher(models.Model):   
  4.     name = models.CharField(maxlength=30)   
  5.     address = models.CharField(maxlength=50)   
  6.     city = models.CharField(maxlength=60)   
  7.     state_province = models.CharField(maxlength=30)   
  8.     country = models.CharField(maxlength=50)   
  9.     website = models.URLField()   
  10.   
  11. class Author(models.Model):   
  12.     salutation = models.CharField(maxlength=10)   
  13.     first_name = models.CharField(maxlength=30)   
  14.     last_name = models.CharField(maxlength=40)   
  15.     email = models.EmailField()   
  16.     headshot = models.ImageField(upload_to='/tmp')   
  17.   
  18. class Book(models.Model):   
  19.     title = models.CharField(maxlength=100)   
  20.     authors = models.ManyToManyField(Author)   
  21.     publisher = models.ForeignKey(Publisher)   
  22.     publication_date = models.DateField()  

這章我們會談到模型語法和選項,讓我們先來快速的看看這些代碼來得到基本的印象
要注意的第一點是每個模型都是django.db.models.Model的子類
它們的父類Model包含了讓這些對象具有與數(shù)據(jù)庫交互能力的機制
這樣一來我們的模型只負責定義自己的域就行了,語法相當簡潔緊湊
不管相信與否,這就是通過Django進行數(shù)據(jù)訪問的所有代碼
一個模型通常域一個數(shù)據(jù)庫表對應,而每個屬性和數(shù)據(jù)庫表的一列對應
屬性名對應列名,屬性的類型(如CharField)對應數(shù)據(jù)庫列類型
例如Publisher模型對應了下面的表(假設使用PostgreSQL的CREATE TABLE語法):
Java代碼 復制代碼
  1. CREATE TABLE "books_publisher" (   
  2.     "id" serial NOT NULL PRIMARY KEY,   
  3.     "name" varchar(30) NOT NULL,   
  4.     "address" varchar(50) NOT NULL,   
  5.     "city" varchar(60) NOT NULL,   
  6.     "state_province" varchar(30) NOT NULL,   
  7.     "country" varchar(50) NOT NULL,   
  8.     "website" varchar(200) NOT NULL   
  9. );  

事實上Django自己可以生成CREAT TABLE語句,我們一會再看
一個類對應一個數(shù)據(jù)庫表的特例是多對多關系,我們的例子中Book有一個ManyToManyField叫作authors
這表明book擁有一個或多個authors,但是Book表并沒有authors列
Django創(chuàng)建了一個附加的多對多連接表來處理books到authors的映射
最后注意的是我們沒有在任何一個模型中顯示的定義主鍵
除非你自己定義一個主鍵,Django會自動為每個模型生成一個integer主鍵域id
每個Django模型都必須有一個單列的主鍵

安裝模型
寫完代碼,下面讓我們來創(chuàng)建數(shù)據(jù)庫表
第一步是在Django中激活這些模型,需要把books這個app添加到settings文件的apps列表
編輯settings.py,查找INSTALLED_APPS設置
INSTALLED_APPS告訴Django哪些apps是活動的,默認時如下所示:
Java代碼 復制代碼
  1. INSTALLED_APPS = (   
  2.     'django.contrib.auth',   
  3.     'django.contrib.contenttypes',   
  4.     'django.contrib.sessions',   
  5.     'django.contrib.sites',   
  6. )  

先用(#)把這些strings注釋掉,后面我們再激活和討論它們
然后添加'mysite.books'到INSTALLED_APPS列表,最后如下所示:
Java代碼 復制代碼
  1. INSTALLED_APPS = (   
  2.     #'django.contrib.auth',   
  3.     #'django.contrib.contenttypes',   
  4.     #'django.contrib.sessions',   
  5.     #'django.contrib.sites',   
  6.     'mysite.books',   
  7. )  

別忘了最后的逗號
順便說一下,本書作者習慣與在元組的元素后面都加上逗號,無論元組是否只有一個元素
這可以避免忘記加逗號,加了也不會罰款
'mysite.books'指我們正在工作的books app
INSTALLED_APPS中的每個app都用完整的Python PATH來表示,即包的PATH,用小數(shù)點分隔來指向app包
Django app已經(jīng)在settings文件激活,我們可以在數(shù)據(jù)庫中創(chuàng)建表了
首先通過如下的命令驗證一下模型:python manage.py validate
validate命令檢查我們的模型語法和邏輯正確與否
如果一切正常,我們會看到0 errors found的信息
否則,確認你的模型代碼輸入正確,error輸出會給你有用的信息來幫你找到錯誤的代碼
任何時候你認為你的模型代碼有問題都可以運行python manage.py validate來捕捉模型錯誤
如果你的模型是合法的,運行下面的命令為books app的模型生成CREATE TABLE語句
(如果你使用Unix會有五顏六色的語法高亮):python manage.py sqlall books
這個命令中,books是app的名字,運行完命令,你會看到下面的信息:
Java代碼 復制代碼
  1. BEGIN;   
  2. CREATE TABLE "books_publisher" (   
  3.     "id" serial NOT NULL PRIMARY KEY,   
  4.     "name" varchar(30) NOT NULL,   
  5.     "address" varchar(50) NOT NULL,   
  6.     "city" varchar(60) NOT NULL,   
  7.     "state_province" varchar(30) NOT NULL,   
  8.     "country" varchar(50) NOT NULL,   
  9.     "website" varchar(200) NOT NULL   
  10. );   
  11. CREATE TABLE "books_book" (   
  12.     "id" serial NOT NULL PRIMARY KEY,   
  13.     "title" varchar(100) NOT NULL,   
  14.     "publisher_id" integer NOT NULL REFERENCES "books_publisher" ("id"),   
  15.     "publication_date" date NOT NULL   
  16. );   
  17. CREATE TABLE "books_author" (   
  18.     "id" serial NOT NULL PRIMARY KEY,   
  19.     "salutation" varchar(10) NOT NULL,   
  20.     "first_name" varchar(30) NOT NULL,   
  21.     "last_name" varchar(40) NOT NULL,   
  22.     "email" varchar(75) NOT NULL,   
  23.     "headshot" varchar(100) NOT NULL   
  24. );   
  25. CREATE TABLE "books_book_authors" (   
  26.     "id" serial NOT NULL PRIMARY KEY,   
  27.     "book_id" integer NOT NULL REFERENCES "books_book" ("id"),   
  28.     "author_id" integer NOT NULL REFERENCES "books_author" ("id"),   
  29.     UNIQUE ("book_id""author_id")   
  30. );   
  31. CREATE INDEX books_book_publisher_id ON "books_book" ("publisher_id");   
  32. COMMIT;  

注意以下幾點:
1,表明自動由app名(books)和小寫的模型名-publisher,book和author組成
你可以覆蓋這個行為,我們本章后面會看到
2,前面提到,Django自動給每個表添加主鍵id域,你也可以覆蓋這點
3,習慣約束上Django會在外鍵域的名字后面添加“_id”,你已經(jīng)猜到了,你也可以覆蓋這點
4,外鍵關系由顯式的REFERENCES語句來完成
5,這些CREATE TABLE語句是針對你使用的數(shù)據(jù)庫生成的,所以數(shù)據(jù)庫專有的域類型如
aotu_increment(MySQL),serial(PostgreSQL),或者integer primary key(SQLite)會自動為你處理
類似的如表名的引號是使用單引號還是雙引號也一樣,這個例子是使用的PostgreSQL語法
sqlall命令事實上并沒有接觸數(shù)據(jù)庫或建表,它僅僅將輸出打印到屏幕上
所以如果你問它,你可以看到DJango將執(zhí)行什么
如果你愿意,你可以復制粘貼這些SQL到你數(shù)據(jù)庫客戶端或者使用Unix管道來直接傳遞它
盡管如此,Django提供一個簡單的方式來把這些SQL提交數(shù)據(jù)庫
像下面這樣運行syncdb命令:python manage.py syncdb
你會看到如下信息:
Creating table books_publisher
Creating table books_book
Creating table books_author
Installing index for books.Book model
syncdb簡單的把你的模型同步到數(shù)據(jù)庫
它檢查數(shù)據(jù)庫和你的INSTALLED_APPS中的所有app的所以模型,看看是否有些表已經(jīng)存在,如果表不存在就創(chuàng)建表
注意syncdb不會同步改動或刪除了的模型,如果你改動或刪除了一個模型,syncdb不會更新數(shù)據(jù)庫(待會兒討論這個)
如果你再運行一次python manage.py syncdb,不會發(fā)生任何事情
因為你沒有添加模型到books app或添加到INSTALLED_APPS中的任何app
因此運行python manage.py syncdb是一直安全的,它不會把事情弄糟
如果你感興趣,進入你的數(shù)據(jù)庫服務器的命令行客戶端看看Django創(chuàng)建的數(shù)據(jù)庫表
你可以手動運行命令行客戶端如PostgreSQL的psql,或者運行python manage.py dbshell
基于你的DATABASE_SERVER設置,后者將計算出運行哪個命令行客戶端,也更方便

數(shù)據(jù)訪問基礎
一旦你創(chuàng)建了一個模型,Django自動提供高級Python API給這些模型工作
運行python manage.py shell然后輸入下面的代碼試試:
Java代碼 復制代碼
  1. >>> from books.models import Publisher   
  2. >>> p = Publisher(name='Apress', address='2560 Ninth St.',   
  3. ...     city='Berkeley', state_province='CA', country='U.S.A.',   
  4. ...     website='http://www.apress.com/')   
  5. >>> p.save()   
  6. >>> p = Publisher(name="O'Reilly", address='10 Fawcett St.',   
  7. ...     city='Cambridge', state_province='MA', country='U.S.A.',   
  8. ...     website='http://www.oreilly.com/')   
  9. >>> p.save()   
  10. >>> publisher_list = Publisher.objects.all()   
  11. >>> publisher_list   
  12. [<Publisher: Publisher object>, <Publisher: Publisher object>]  

雖然只有幾行代碼,確達到了很多目的,精彩的部分是:
1,創(chuàng)建一個對象只需import合適的模型類并通過給每個域傳遞值來初始化它
2,調(diào)用save()方法來將一個對象保存到數(shù)據(jù)庫,后臺Django在這里執(zhí)行了一條INSERT SQL語句
3,使用Publisher.objects屬性從數(shù)據(jù)庫得到對象,使用Publisher.objects.all()得到Publisher所有的對象列表
后臺Django在這里執(zhí)行了一條SELECT SQL語句
實際上你可以通過Django數(shù)據(jù)庫API做很多事情,但是我們先來看一個小麻煩

添加模型的string顯示
上面的例子中,當我們打印publishers列表時我們得到的都是一些無用的信息,我們很難將Publisher對象區(qū)別開:
[<Publisher: Publisher object>, <Publisher: Publisher object>]
我們可以通過給Publisher對象添加一個__str__()方法來輕松解決這個問題
__str__()方法告訴Python怎樣顯示對象的string顯示,你可以動手來看看給三個模型添加__str__():
Java代碼 復制代碼
  1. class Publisher(models.Model):   
  2.     name = models.CharField(maxlength=30)   
  3.     address = models.CharField(maxlength=50)   
  4.     city = models.CharField(maxlength=60)   
  5.     state_province = models.CharField(maxlength=30)   
  6.     country = models.CharField(maxlength=50)   
  7.     website = models.URLField()   
  8.   
  9.     def __str__(self):   
  10.         return self.name   
  11.   
  12. class Author(models.Model):   
  13.     salutation = models.CharField(maxlength=10)   
  14.     first_name = models.CharField(maxlength=30)   
  15.     last_name = models.CharField(maxlength=40)   
  16.     email = models.EmailField()   
  17.     headshot = models.ImageField(upload_to='/tmp')   
  18.   
  19.     def __str__(self):   
  20.         return '%s %s' % (self.first_name, self.last_name)   
  21.   
  22. class Book(models.Model):   
  23.     title = models.CharField(maxlength=100)   
  24.     authors = models.ManyToManyField(Author)   
  25.     publisher = models.ForeignKey(Publisher)   
  26.     publication_date = models.DateField()   
  27.   
  28.     def __str__(self):   
  29.         return self.title  

你可以看到,__str__()方法為了返回一個string顯示可以做任何它需要做的事情
這里Publisher和Book的__str__()方法簡單的返回了對象的name和title
但是Author的__str__()更復雜一點,返回了first_name和last_name的組合
__str__()唯一的條件是返回一個string,如果不返回string的話如返回一個integer
Python會觸發(fā)一個TypeError異常,并帶有“__str__ returned non-string”信息
為了讓改動生效,退出Python然后使用python manage.py shell命令重新進入
(這是讓代碼改動生效的最簡單的方式)
現(xiàn)在,Publisher列表對象更容易理解:
Java代碼 復制代碼
  1. >>> from books.models import Publisher   
  2. >>> publisher_list = Publisher.objects.all()   
  3. >>> publisher_list   
  4. [<Publisher: Apress>, <Publisher: O'Reilly>]  

確認你定義的任何模型都有一個__str__()方法,不僅是使在你自己使用交互環(huán)境時更方便
也因為當Django在幾個地方需要顯示對象時會使用__str__()的輸出
最后,注意__str__()是給模型添加行為的好習慣
一個Django模型描述的不僅僅是一個對象數(shù)據(jù)庫表結構,它也描述了對象知道怎樣去做的功能
__str__()就是這樣的功能的一個例子,一個模型知道怎樣顯示它自己


安徽新華電腦學校專業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢
主站蜘蛛池模板: 日本欧美在线 | 亚洲国产一区二区三区四区 | 91最新| 在线成人免费 | 韩日在线观看视频 | 欧美色图另类 | 一区二区精品在线 | 中文字幕综合 | 午夜看片| 精品亚洲一区二区三区 | 国产一级色 | 国产精品免费在线 | h视频免费看 | 黄色大片网 | 国产中文字幕在线 | 丁香午夜 | 亚洲日本欧美日韩高观看 | 欧美男男videos | 久草热8精品视频在线观看 黄色片网站视频 | 日韩免费视频 | 成人在线播放器 | 亚洲视频在线免费观看 | 国产91福利视频 | 可以在线观看的av网站 | 天天看片天天干 | 精品一二三区 | 欧美日韩国产一区二区 | 中文字幕一区二区三区四区不卡 | 免费黄色在线看 | 91亚洲国产成人久久精品网站 | 亚洲精品在线免费观看视频 | av在线播放国产 | 精品久久久久久久 | 国产高清在线 | 日韩欧美在线视频 | 国产精品一区久久久久 | 1区2区免费视频 | 日韩欧美一区二区在线 | 欧洲尺码日本国产精品 | 色综久久 | 成年人视频在线免费观看 | 国产精品久久久久久久久久久久久 | 国产精品夜色一区二区三区 | 亚洲成人一区二区三区 | 999热在线 | 免费观看成人性生生活片 | 91色在线| 狠狠操综合网 | 在线观看国产日韩欧美 | 婷婷综合五月天 | 精品国产一区二区三区成人影院 | 欧美极品一区 | 在线a电影 | 国产99精品 | av三级 | 伊人影院在线观看 | 国产区日韩区欧美区 | 97超碰免费 | 欧美一级视频在线观看 | t66y最新地址一地址二69 | 久久女同互慰一区二区三区 | 成人亚洲精品 | 亚洲免费影院 | 精品久久久久一区二区国产 | 最近的中文字幕在线看视频 | 国产欧美日韩精品一区二区三区 | 亚洲91精品 | 国产成人在线播放 | 久久成年人视频 | 四虎黄色网 | 一区二区中文字幕 | 黑人精品xxx一区一二区 | 在线视频中文字幕 | 成人深夜福利 | 高清国产一区二区三区四区五区 | xxxx欧美 | 国产精品久久久久无码av | 在线观看国产 | 狠狠操夜夜爱 | 国产1区在线观看 | 国产亚洲视频在线观看 | 欧美日韩国产一区二区三区在线观看 | 亚洲人成人一区二区在线观看 | 日韩精品久久 | 天天操天天碰 | 可以免费看黄视频的网站 | 一二三四区视频在线观看 | 成人一级电影在线观看 | 国产成人av一区二区 | 亚洲五月婷婷 | 97国产精品 | 精品久久久久久久久久久下田 | 亚洲成人免费网站 | 91中文在线观看 | 国产欧美日韩综合精品一区二区 | 91精品日韩| 欧美黄色片 | 午夜精品久久久久久久 | 日本a v在线播放 | 玖玖精品在线 | 国产成人午夜精品影院游乐网 | 日韩午夜影院 | 日韩成年人视频 | 在线色站 | 精品久久久久久久久久久久 | 日韩欧美国产网站 | 可以免费在线观看av的网站 | 中文字幕八区 | 中文字幕av一区 | 亚洲香蕉在线观看 | 欧洲精品久久久 | 成人欧美 | 国产高清中文字幕 | 国产精品久久久久婷婷二区次 | 爱草在线 | 久久久久网站 | 日韩av一区二区三区四区 | 国产福利电影一区 | 国产精品成人在线观看 | 亚洲精品日韩在线 | 国产一级片| h片免费| www.在线播放 | 精品视频免费观看 | 久草视频在线播放 | 成人区一区二区三区 | 国产做a爰片久久毛片a我的朋友 | 亚洲成人国产精品 | 一区视频在线 | 日本精品一区二 | 色综合久久88色综合天天 | 四虎视频| 午夜影院a | 久草视频播放 | 欧美成人h版在线观看 | 精品久久久久久久久久久院品网 | 精品日韩一区二区 | 国产中文字幕一区 | 久久精品久久综合 | 欧美亚洲一区 | 偷偷干夜夜拍 | 欧美一区精品 | 免费国产wwwwwww网站 | 欧美在线观看免费观看视频 | 美女一级a毛片免费观看97 | 午夜国产精品视频 | 免费视频一区二区三区在线观看 | 亚洲高清视频网站 | 亚洲成人av一区二区三区 | 国产精品久久久一区二区 | 亚洲三区在线观看 | 中文字幕亚洲一区 | 欧美一级特黄aaaaaa大片在线观看 | 国产精品久久久久久中文字 | 一区二区三区无码高清视频 | 一区二区三区免费 | 久久久av | 伊人网在线观看 | 午夜视频黄 | 鲁管视频 | 龙珠z在线观看 | 国产精品一区av | www.久久| 欧美精品欧美激情 | 狠狠艹视频 | 毛片在线视频 | 免费国产黄色大片 | 欧美激情一区二区三区在线视频 | 国产精品久久久久久久久久 | 亚洲精品视频在线播放 | 亚洲三级视频 | 在线免费黄色小视频 | 欧美综合成人网 | 国产超碰人人爽人人做人人爱 | 色网站在线观看 | 久久综合成人精品亚洲另类欧美 | 97av在线| 国产97在线 | 亚洲 | 国产欧美精品一区二区三区四区 | 在线播放亚洲 | 操片| 久久久精品久久久久久 | 亚洲精品大片 | 一区二区亚洲 | 中文字幕视频在线 | 国产ts人妖另类 | 精品一区二区在线观看 | 成人欧美一区二区三区视频xxx | 日韩欧美大片在线观看 | 日韩色综合 | 久久综合久久综合久久 | 中文字幕日韩欧美一区二区三区 | av毛片免费| 欧美日韩一区在线观看 | 日本狠狠色 | 欧美在线一区二区 | 亚洲精品成人 | 中文字幕 在线观看 | 欧美一区2区三区4区公司二百 | 欧美激情在线精品一区二区三区 | 91大神免费在线观看 | 国产一区不卡视频 | 国产精品国产精品国产专区不卡 | 日韩国产欧美精品 | 国产精品视频 | 午夜成人免费影院 | 韩日一区 | 一区二区在线看 | aaaa大片| 午夜精品久久 | 天天色天天色 | 日本午夜在线 | 亚洲欧洲精品一区二区 | 99爱在线观看 | 欧美国产日韩在线观看 | 一级黄色影片在线观看 | 中国特级黄色片 | 日韩在线中文 | 色一情一乱一伦一区二区三区 | 91精品国产欧美一区二区成人 | 欧美自拍视频一区 | 91视频专区 | 性视频一区二区 | 欧美日韩一区二区在线 | 国产一区二区精品 | 秋霞av电影 | 亚洲综合色自拍一区 | av观看免费 | 国内久久精品 | 免费毛片一区二区三区久久久 | 国产高清久久久 | 一级全毛片 | 少妇淫片aaaaa毛片叫床爽 | 国产欧美一区二区精品久久 | 中文字幕精品三区 | 亚洲成人久久久 | 亚洲看片网站 | 龙珠z国语291集普通话 | h视频免费在线 | 男女精品| 综合久久综合久久 | 91中文字幕在线观看 | 日韩精品一区二区三区在线观看 | 日韩欧美在线看 | 久久久成人av | 久久国产精品99久久久久久老狼 | 日韩精品一区二区三区中文字幕 | 婷婷激情五月 | 日韩午夜免费视频 | 91成人在线免费视频 | 精品日韩av | 91亚洲免费 | 精品美女在线观看视频在线观看 | 成人一区二区在线 | 国产91网址 | 国产91亚洲精品 | 国产午夜一区二区三区 | 国产三级精品在线 | 日韩在线不卡 | 亚洲精品91 | 欧美一级性| 国产在视频一区二区三区吞精 | 日本视频中文字幕 | 亚洲精品乱码久久久久久蜜桃不爽 | 国产97色在线 | 亚洲 | 性一级录像片片视频免费看 | 国产精品99一区二区三区 | 成人精品一区二区三区 | 在线日韩中文字幕 | 久久美女视频 | 国产欧美精品一区二区色综合朱莉 | 国产乱码一区二区三区在线观看 | 日韩免费视频一区二区 | 黄色成人在线网站 | 国产精品免费在线 | 久久99精品久久久久蜜臀 | 中文字字幕在线 | 欧美久久久久久久 | 精品久久久久av | 免费观看一级毛片 | 国产精彩视频 | 免费在线视频精品 | 国产a视频| av手机在线电影 | 国产日韩精品一区二区 | 亚洲电影一区二区三区 | 国产乱xxxxx97国语对白 | 久热99| 亚洲高清视频一区 | 99热在线播放 | 精品国产一区二区三区高潮视 | 黑人精品xxx一区一二区 | 国产精品2区 | 国产毛片毛片 | 成人免费福利 | 91精品国产综合久久婷婷香蕉 | 中文字幕久久精品 | 91精品国产乱码久久蜜臀 | 亚洲国产中文字幕 | 欧美日韩一区二区三区免费视频 | 日本视频中文字幕 | 欧美精品一区三区 | 日韩国产欧美一区 | 夜夜草视频 | 久久久久无码国产精品一区 | 天天操狠狠操 | 免费毛片网 | 一级黄色生活视频 | www久久精品| 中文字幕日韩欧美一区二区三区 | 欧美日韩亚洲三区 | 国产日韩精品视频 | h片在线看| 精品福利av导航 | 国产一区二区视频在线观看 | 日韩欧美在线一区 | 青青久久久 | 欧美一级高潮片免费的 | 91亚洲高清| 国产视频三区 | 凹凸日日摸日日碰夜夜爽孕妇 | 夜夜骑天天干 | 欧美精品在线视频 | 国产欧美日韩综合精品 | 精品国产18久久久久久二百 | 狠狠色狠狠色综合网 | 理论片一区 | 噜噜噜在线观看免费视频日本 | 成人免费观看视频 | 国产一级大片 | 日韩综合网 | 亚洲欧美成人网 | 国产中文字幕在线观看 | 在线一区二区三区视频 | 久久精品国产视频 | 亚洲精品一区二区另类图片 | 美女91 | 杏导航aⅴ福利网站 | 欧美日韩国产综合网 | 91高清在线观看 | 日韩亚洲视频在线观看 | 国产精品国产精品国产专区不卡 | wwwjizz日本| 97视频久久久 | 二区在线视频 | 羞羞视频在线播放 | 一区二区三区 在线 | 久久1区 | 精品视频久久 | 亚洲成人av在线 | 国产中文字幕在线 | 欧美日韩免费在线 | 国产精品1区2区3区 国产在线观看一区 | 亚洲人网站 | 国产精品久久久久久久久久久久久 | 色视频网站免费看 | 中文字幕第一页在线视频 | 久久久久无码国产精品一区 | 国产精品亚洲一区二区三区在线 | 精品久久久久久久久久久久 | 高清国产一区二区三区 | 欧美精品欧美精品系列 | 亚洲国产成人av好男人在线观看 | 国产精选一区二区三区 | 免费av在线 | 蜜桃免费视频 | 国产视频欧美 | 日韩成人在线观看 | 精品视频一区二区三区 | 亚洲国产精品一区 | 国产精品美女视频 | 北条麻妃99精品青青久久 | www国产在线观看 | 亚洲天堂一区二区 | 欧美激情小视频 | 国产视频1区 | 久久久99精品免费观看 | 日韩一区二区三区在线播放 | 国产伦精品一区二区三区四区视频_ | 蜜桃免费视频 | 亚洲成a | 日本精品一区二区三区在线观看视频 | 人人艹人人爽 | 97视频久久久 | 毛片在线视频 | 91精品一区二区三区久久久久久 | a级在线免费视频 | 四虎永久在线观看 | 美女视频一区 | 99亚洲精品 | 亚洲一区 中文字幕 | 久久精品99国产精品亚洲最刺激 | 蜜桃av人人夜夜澡人人爽 | 中文无码久久精品 | 国产精品成人在线观看 | 9999国产精品欧美久久久久久 | 亚洲一区二区免费在线观看 | 99精品在线| 国产成人综合一区二区三区 | av网站免费 | www.久久久.com | 久久久久av| 国产成人在线一区 | 91在线视频播放 | 亚洲第一成年免费网站 | 国产视频久久久久 | 欧美一区二区三区精品 | 亚洲一区在线日韩在线深爱 | 亚洲成人一区二区三区 | 日韩av免费在线观看 | 欧美一区二区三区四区五区 | 欧美一级黄视频 | 欧美精品99 | 一区国产精品 | 麻豆精品一区二区 | 毛片国产| 国产成人精品一区二 | 午夜天堂精品久久久久 | 免费黄色网址在线播放 | 午夜精品一区二区三区四区 | 一级毛片大全免费播放 | 天天操天天插 | 国产精品久久久久久久久久ktv | 中文字幕第一页在线 | 成人在线观看h | 精品中文字幕一区二区三区 | 久久久久久国产精品 | www.日韩视频 | 一区二区三区不卡视频 | 午夜在线视频 | 欧美一区二区精品 | 日本中文在线 | 草草草久久久 | 亚洲国产一区在线 | 中文字幕一区在线观看视频 | 中文字幕亚洲一区二区三区 | 久久精品在线观看视频 | 国内在线一区 | 欧美日韩精品一区 | 久久久久久国产精品 | 国产偷自视频区视频 | 久草免费在线 | 久久伦理电影 | 天天综合网91 | 精品国产一区二区三区在线观看 | 国产精品网站在线 | 亚洲精品一区在线观看 | 成人片免费看 | 亚洲一区二区 | 欧美日韩一区二区在线播放 | 国产在线精品一区二区三区 | 精品免费久久久久 | 国产精品1区2区在线观看 | 成人a在线视频免费观看 | 亚洲欧洲精品一区二区三区 | 毛片免费网站 | 亚洲精品久久久久久久久久久 | 午夜成人在线视频 | 成人久久| 国产成人aⅴ | 中文字幕视频免费观看 | 久草青青 | 特级黄一级播放 | 国产小视频在线 | 国产综合精品 | 久久国产精品免费一区二区三区 | 日本成人一二三区 | 91精品久久久久久久久中文字幕 | 日日操天天射 | 毛片免费观看视频 | 婷婷免费在线观看 | 精品久久久久久国产 | 成人在线播放 | 午夜久久 | 欧美久久一区二区三区 | 国产九九九 | 久久精品国产99国产精品 | av在线官网 | 国产精品久久一区二区三区 | 久草电影网 | 99视频这里有精品 | 亚洲综合在 | 日韩欧美中文在线 | 国产精品无码专区在线观看 | 色呦呦网站在线观看 | 最新免费av网站 | 91久久精品一区二区别 | 欧美一区二区三区免费 | 亚洲热在线观看 | www.日韩在线观看 | 国产高清精品在线 | 99视频在线免费观看 | 蜜桃视频在线播放 | 伊人草 | 免费中文字幕 | 国产精品中文字幕在线 | 中文字幕在线观看不卡视频 | 国产精品一区二区久久 | 欧美大成色www永久网站婷 | 亚洲一区免费视频 | 人人看人人插 | 国产精品一二 | 久久久久国产一级毛片高清版小说 | www.天天操.com | 日韩av在线一区 | 久久久国产视频 | 中文字幕视频在线免费观看 | 久久亚洲欧美日韩精品专区 | 欧美a级成人淫片免费看 | 国产精品三级视频 | 99国产精品 | 午夜影院入口 | 亚洲高清视频网站 | 亚洲国产一区二区在线观看 | 欧美成人黑人xx视频免费观看 | 一区二区三区四区在线播放 | 亚洲成人三级 | 亚洲成年人影院 | 在线三级电影 | 欧美综合国产精品久久丁香 | 国产精品久久久久久久久久妞妞 | 在线观看欧美日韩视频 | 福利精品在线观看 | 日日摸天天做天天添天天欢 | 国产在线精品一区二区 | 久久久影院 | 在线视频国产一区 | 中文字幕一区二区在线观看 | 天天干天操| 午夜av在线 | 中文亚洲 | 午夜视频在线观看网站 | 国产欧美日韩综合精品 | 国产成人精品久久二区二区91 | 亚洲精品视频在线播放 | 亚洲视频在线观看免费 | 国产乱码精品一区二区三区中文 | 国产欧美精品一区二区三区四区 | 一二三区字幕免费观看av | 日韩视频精品在线观看 | 中文欧美日韩 | 国内精品国产三级国产在线专 | 日韩一区二区免费视频 | 国产精品99精品久久免费 | 亚洲国产精品久久久久 | 狠狠入ady亚洲精品经典电影 | 久久久国产一区二区三区 | 91亚洲视频| 午夜合集 | 国产999精品久久久久久 | 97在线观看视频 | 欧美日韩亚洲一区二区 | 亚洲欧洲一区二区 | 九一在线观看 | 毛片在线视频 | 国产一区二区三区免费观看 | 欧美精品成人 | 黄色片网站在线看 | 中文字幕在线观看视频一区 | 国产精品亚洲一区 | 亚洲一级黄色 | 国产欧美在线观看 | 一级黄色影片在线观看 | 亚洲 欧美日韩 国产 中文 | 国精产品一区一区三区免费完 | 亚洲欧美一区二区精品中文字幕 | 久久久男人天堂 | 最新国产精品精品视频 | 精品视频一区二区三区在线观看 | 欧美精品一区自拍a毛片在线视频 | 综合一区二区三区 | 精品国产乱码久久久久久88av | 国产亚洲视频在线观看 | 久草精品视频在线播放 | 91在线视频播放 | 精品一区在线 | 亚洲www.| 男女午夜 | 亚洲精品国产第一综合99久久 | 免费看一区二区三区 | 国产精品视频一区二区三区不卡 | 日韩精品一区二区在线观看视频 | 欧美区 日韩区 | 91精品国产综合久久精品 | 成人精品一区二区三区中文字幕 | 国产精品久久精品 | av一区在线观看 | 色婷婷久久一区二区三区麻豆 | 亚洲一区不卡在线 | 99爱精品在线 | 成人超碰在线 | 亚洲毛片在线观看 | 最新国产在线视频 | 久久com| 日韩视频网站在线观看 | 色欧美片视频在线观看 | 精品久久影院 | 亚洲精品乱码久久久久久9色 | 亚洲成人综合网站 | 欧美一级在线观看 | 久久精品99国产精品亚洲最刺激 | 一级毛片视频 | 亚洲成人激情在线观看 | 亚洲九九| 久久久久一区二区三区 | 日韩成人一区 | 成人在线看片 | 9uu在线观看 | 黄色一级毛片 | 国产欧精精久久久久久久 | 国产欧美精品在线 | 精品成人在线视频 | 午夜午夜精品一区二区三区文 | 999久久久 | 日本免费一区二区在线观看 |