• <noscript id="e0iig"><kbd id="e0iig"></kbd></noscript>
  • <td id="e0iig"></td>
  • <option id="e0iig"></option>
  • <noscript id="e0iig"><source id="e0iig"></source></noscript>
  • Django框架入門 -- (四)數據模型及數據庫的操作

    1.根據表字段定義類

    【案例】假設有兩張表:person表和order表,字段分別如下。

    person表中有四個字段:first_name(字符串),last_name(字符串),created_at(日期類型),updated_at(日期類型)。

    order表中有四個字段:order_id(FK),order_desc(字符串),created_at,updated_at。

    則在models.py內編寫的代碼如下:

    from django.db import models
    
    
    # 模型類需要繼承一個父類
    class Person(models.Model):
        # 表中有四個字段:first_name(字符串),last_name(字符串),created_at(日期類型),updated_at
        # 需要在Person類中生成這四個字段
        first_name = models.CharField(max_length=30)
        last_name = models.CharField(max_length=30)
        created_at = models.DateField(auto_now_add=True)
        updated_at = models.DateField(auto_now=True)
        
    
    class Order(models.Model):
        # order_id(FK),order_desc(訂單描述),created_at,updated_at
        order_id = models.CharField(max_length=30, db_index=True)
        order_desc = models.CharField(max_length=100)
        created_at = models.DateField(auto_now_add=True)
        updated_at = models.DateField(auto_now=True)

    其中created_at,updated_at是兩張表都有的字段,可以提取到一個類中。

    from django.db import models
    
    
    # 相同字段可以提取一個類,沒有對應數據庫中的某張表
    class CreateUpdate(models.Model):
        created_at = models.DateField(auto_now_add=True)
        updated_at = models.DateField(auto_now=True)
    
        # 這樣生成數據庫時候就不會生成此表
        class Meta:
            abstract = True
    
    
    # 模型類需要繼承一個父類
    class Person(CreateUpdate):
        # 表中有四個字段:first_name(字符串),last_name(字符串),created_at(日期類型),updated_at
        # 需要在Person類中生成這四個字段
        first_name = models.CharField(max_length=30)
        last_name = models.CharField(max_length=30)
    
    
    class Order(CreateUpdate):
        # order_id(FK),order_desc(訂單描述),created_at,updated_at
        order_id = models.CharField(max_length=30, db_index=True)
        order_desc = models.CharField(max_length=100)

    2.配置連接mysql數據庫

    打開demo下的settings.py文件,對數據庫配置部分進行修改:

    修改內容:

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'db_django_demo',  # 數據庫名
            'USER': 'root',
            'PASSWORD': '123456'
        }
    }

    3.連接mysql數據庫

    (1)打開數據庫圖形化工具,新建一個數據庫,名稱為:db_django_demo。

    (2)安裝mysql數據庫驅動(sqlite不需要安裝):

    (base) E:\workspace\pycharm\django\start_demo\demo>pip install pymysql

    (3)引入mysql驅動模塊:

    import pymysql
    
    pymysql.install_as_MySQLdb()

    (4)將models.py中的數據模型轉換為數據表:

    (base) E:\workspace\pycharm\django\start_demo\demo>python manage.py makemigrations

    (5)遷移數據,生成數據表:

    (base) E:\workspace\pycharm\django\start_demo\demo>python manage.py migrate

    此時兩張表已生成:

    查看數據表:

    4.插入數據

    (base) E:\workspace\pycharm\django\start_demo\demo>python manage.py shell

    進入python交互的命令行:

    編寫以下python代碼:

    (base) E:\workspace\pycharm\django\start_demo\demo>python manage.py shell
    Python 3.7.4 (default, Aug  9 2019, 18:34:13) [MSC v.1915 64 bit (AMD64)]
    Type 'copyright', 'credits' or 'license' for more information
    IPython 7.8.0 -- An enhanced Interactive Python. Type '?' for help.
    
    In [1]: from app1.models import Person,Order
    
    In [2]: Person.objects.create(first_name="Li",last_name="lei")
    Out[2]: <Person: Person object (1)>

    此時查看數據表,數據已插入:

     

    版權聲明:本文為m0_38056893原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接和本聲明。
    本文鏈接:https://blog.csdn.net/m0_38056893/article/details/102671668

    智能推薦

    Django入門(四)   簡單操作數據庫

        經過前面三節的練習,我們已經可以將一個頁面動態的展現給用戶了。但是真正動態語言還需要連接數據庫,將數據庫中的內容讀取出來呈現在給客戶。這一節我們就來實現簡單的讀寫數據庫,對數據庫進行增刪改查等操作。     前面我們講過django有一個全局的配置文件settings.py,這個文件位于子目錄myjango下面...

    四.驅動框架入門之LED(中)

    接上篇:https://blog.csdn.net/wangweijundeqq/article/details/101696862 目錄 五.基于驅動框架寫led驅動1 5.1、分析 5.2、動手寫led驅動模塊 六.基于驅動框架寫led驅動2 6.1、代碼實踐 七.基于驅動框架寫led驅動3 7.1、在驅動中將4個LED分開 7.2、和leds-s3c24xx.c的不同 7.3、gpiolib...

    React框架入門學習(四)-----個人博客搭建

        采用 Semantic-UI ,鏈接是: https://react.semantic-ui.com/     下面介紹使用方法,Semantic-UI團隊已經做好了許多React組件,我們只需要根據官方網頁中的提示引入React組件就可以使用。在使用之前,先要在我們本地的React項目里安裝Semantic-...

    SpringBoot框架入門(四、dubbo常用屬性介紹)

    在dubbo中我們會看到許多標簽屬性,如常見的timeout,version,group,這些屬性都有自己代表的意義,這次屬性的不同配置也會對我們的項目產生不同的影響。 幾種配置的介紹 配置名稱 配置應用 RegistryConfig 注冊中心配置,用于配置連接注冊中心相關信息 ProtocolConfig 協議配置,用于配置提供服務的協議信息 ApplicationConfig 用于配置當前應用...

    HTML中常用操作關于:頁面跳轉,空格

    1.頁面跳轉 2.空格的代替符...

    猜你喜歡

    freemarker + ItextRender 根據模板生成PDF文件

    1. 制作模板 2. 獲取模板,并將所獲取的數據加載生成html文件 2. 生成PDF文件 其中由兩個地方需要注意,都是關于獲取文件路徑的問題,由于項目部署的時候是打包成jar包形式,所以在開發過程中時直接安照傳統的獲取方法沒有一點文件,但是當打包后部署,總是出錯。于是參考網上文章,先將文件讀出來到項目的臨時目錄下,然后再按正常方式加載該臨時文件; 還有一個問題至今沒有解決,就是關于生成PDF文件...

    電腦空間不夠了?教你一個小秒招快速清理 Docker 占用的磁盤空間!

    Docker 很占用空間,每當我們運行容器、拉取鏡像、部署應用、構建自己的鏡像時,我們的磁盤空間會被大量占用。 如果你也被這個問題所困擾,咱們就一起看一下 Docker 是如何使用磁盤空間的,以及如何回收。 docker 占用的空間可以通過下面的命令查看: TYPE 列出了docker 使用磁盤的 4 種類型: Images:所有鏡像占用的空間,包括拉取下來的鏡像,和本地構建的。 Con...

    requests實現全自動PPT模板

    http://www.1ppt.com/moban/ 可以免費的下載PPT模板,當然如果要人工一個個下,還是挺麻煩的,我們可以利用requests輕松下載 訪問這個主頁,我們可以看到下面的樣式 點每一個PPT模板的圖片,我們可以進入到詳細的信息頁面,翻到下面,我們可以看到對應的下載地址 點擊這個下載的按鈕,我們便可以下載對應的PPT壓縮包 那我們就開始做吧 首先,查看網頁的源代碼,我們可以看到每一...

    Linux C系統編程-線程互斥鎖(四)

    互斥鎖 互斥鎖也是屬于線程之間處理同步互斥方式,有上鎖/解鎖兩種狀態。 互斥鎖函數接口 1)初始化互斥鎖 pthread_mutex_init() man 3 pthread_mutex_init (找不到的情況下首先 sudo apt-get install glibc-doc sudo apt-get install manpages-posix-dev) 動態初始化 int pthread_...

    精品国产乱码久久久久久蜜桃不卡