<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                ### ORM簡介 * MVC框架中包括一個重要的部分,就是ORM,它實現了數據模型與數據庫的解耦,即數據模型的設計不需要依賴于特定的數據庫,通過簡單的配置就可以輕松更換數據庫 * ORM是“對象-關系-映射”的簡稱,主要任務是: * 根據對象的類型生成表結構 * 將對象、列表的操作,轉換為sql語句 * 將sql查詢到的結果轉換為對象、列表 * 這極大的減輕了開發人員的工作量,不需要面對因數據庫變更而導致的無效勞動 * Django中的模型包含存儲數據的字段和約束,對應著數據庫中唯一的表 ![](https://box.kancloud.cn/117f8fc920b32f729d8c94cc996278aa_953x544.png) * * * * * ### 使用MySql數據庫 在虛擬環境中安裝mysql包 ~~~ pip install mysql-python ~~~ 在mysql中創建數據庫 ~~~ create databases test2 charset=utf8 ~~~ 打開settings.py文件,修改DATABASES項 ~~~ DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test2', 'USER': '用戶名', 'PASSWORD': '密碼', 'HOST': '數據庫服務器ip,本地可以使用localhost', 'PORT': '端口,默認為3306', } } ~~~ * * * * * ### 開發流程 1. 在models.py中定義模型類,要求繼承自models.Model 2. 把應用加入settings.py文件的installed_app項 3. 生成遷移文件 4. 執行遷移生成表 5. 使用模型類進行crud操作 * * * * * ### 使用數據庫生成模型類 ~~~ python manage.py inspectdb > booktest/models.py ~~~ ![](https://box.kancloud.cn/343f05c4e89837999b06b30ba0cfee65_1437x476.jpg) ~~~ # models.py #!/usr/bin/env python # -*-coding:utf-8-*- from django.db import models # 自定義管理器 篩選被刪除的 改寫get_queryset() 方法 # 管理器是模型類的屬性,用戶將對象與數據表映射 # 1.更改查詢集 # 2.增加模型類的創建方法,創建模型類對象 class BookInfoManager(models.Manager): def get_queryset(self): return super(BookInfoManager, self).get_queryset().filter(isDelete=False) # 2 初始化類屬性的方法第二種 在管理中定義模型類的創建方法 推薦使用這種方法 def create(cls, btitle, bpub_date): b = BookInfo() b.btitle = btitle b.bpub_date = bpub_date b.bread = 0 b.bcomment = 0 b.isDelete = 0 return b class BookInfo(models.Model): btitle = models.CharField(max_length=20) bpub_date = models.DateTimeField(db_column='pub_date') # 字段別名 bread = models.IntegerField(default=0) # 閱讀量 bcomment = models.IntegerField(null=False) # 評論 null= False 評論不能為空 isDelete = models.BooleanField(default=False) # 邏輯刪除 # 元選項 class Meta: db_table = 'bookinfo' # 表名字 # ordering = ['id'] # 排序 會增加數據庫開銷 book1 = models.Manager() # 原始管理器 book2 = BookInfoManager() # 自定義管理器 # # 1.模型類的init方法不能用(model中有很多方法,不能覆蓋),用類方法的方式創建初始化對象 # @classmethod # def create(cls,btitle,bpub_date): # b = BookInfo() # b.btitle = btitle # b.bpub_date = bpub_date # b.bread = 0 # b.bcomment = 0 # b.isDelete = 0 # return b class HeroInfo(models.Model): hnanme = models.CharField(max_length=10) hgender = models.BooleanField(default=True) hcontent = models.CharField(max_length=1000) isDelete = models.BooleanField(default=False) book = models.ForeignKey(BookInfo) ~~~ ~~~ # views.py #!/usr/bin/env python # -*-coding:utf-8-*- from django.shortcuts import render from django.db.models import Max, F from models import * def index(request): # list = BookInfo.book1.filter(heroinfo__hcontent__contains='六') # list = BookInfo.book1.filter(pk__lge=3) # 聚合函數 # Max1 = BookInfo.book1.aggregate(Max('bpub_date')) # F對象 # list = BookInfo.book1.filter(bread__gt=20) # 閱讀量 list = BookInfo.book1.filter(bread__gt=F('bcomment')) # 閱讀量大于評論量 context = {'list1': list, #'Max1': Max1, } return render(request, 'booktest/index.html', context) ~~~ ~~~ <!---index.html----> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <ul> {% for book in list1 %} <li>{{ book.btitle }}----閱讀量[{{ book.bread }}]---評論量{{ book.bcomment }}</li> {% endfor %} </ul> <!--{{ list1 }}--> <hr> {{ Max1 }} </body> </html> ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看