欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django對數(shù)據(jù)庫進(jìn)行添加與更新的例子

 更新時(shí)間:2019年07月12日 15:44:34   作者:Lex_lht  
今天小編就為大家分享一篇Django對數(shù)據(jù)庫進(jìn)行添加與更新的例子,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

先把models.py擺這兒

#models.py
class UserProfile(AbstractUser):
 '''
 繼承Django的AbstractUser 并向里面添加兩條數(shù)據(jù)內(nèi)容懷疑
 '''
 gender = models.CharField(max_length=6,choices=(('male','男'),('female','女')),default='female',verbose_name='性別')
 memo = models.TextField(null=True, blank=True,verbose_name='便簽')
 class Meta:
  verbose_name = '用戶信息'
  verbose_name_plural = verbose_name #指定模型的復(fù)數(shù)形式是什么,如果不指定Django會(huì)自動(dòng)在模型名稱后加一個(gè)'s'
 
class UserTodo(models.Model):
 created_time = models.DateTimeField(default=datetime.now(),verbose_name='創(chuàng)建時(shí)間')
 user_id = models.ForeignKey(UserProfile,on_delete=models.C ASCADE) #設(shè)置外鍵,關(guān)聯(lián)到UserProfile表
 # models.CASCADE表示若刪除某一用戶,則該用戶下的所有UserTodo也會(huì)被刪除
 ToDolist = models.CharField(max_length=255,verbose_name='todo')
 done = models.BooleanField(default=False,verbose_name='完成狀態(tài)')
 class Meta:
  verbose_name = '用戶自增信息'
  verbose_name_plural = verbose_name

一、將數(shù)據(jù)保存到數(shù)據(jù)庫中(在views.py中)

完成model后,在Terminal運(yùn)行python manage.py makemigrations 生成數(shù)據(jù)庫。然后可以進(jìn)行保存操作

對于沒有沒有外鍵的數(shù)據(jù)庫:

from .models import UserProfile
from django.contrib.auth.hashers import make_password
user_profile = UserProfile()
user_profile.username = username
user_profile.email = email
user_profile.password = make_password(password) #make_password是django自帶的給password重新編碼技術(shù),存儲(chǔ)在數(shù)據(jù)庫中
user_profile.is_active = True #判斷用戶是否激活
user_profile.save()

有外鍵的數(shù)據(jù)庫

1、首先應(yīng)先獲取關(guān)聯(lián)的數(shù)據(jù)庫的信息,如果為用戶則為用的在數(shù)據(jù)庫中的ID

user_id = UserProfile.objects.get(username=request.user) #request.user表示當(dāng)前登陸的用戶名稱,后臺(tái)實(shí)際上是用戶名

2、保存到數(shù)據(jù)庫中

user_todo = UserTodo(ToDolist=todo,done=done,user_id=user_id,created_time=datetime.now()) 保存到數(shù)據(jù)庫中時(shí)按照用戶名所在的id進(jìn)行保存
user_todo.save()

二、對數(shù)據(jù)庫進(jìn)行更新及查詢的操作

動(dòng)機(jī)是當(dāng)用戶點(diǎn)擊網(wǎng)頁上的X號(hào)是對數(shù)據(jù)庫中的done進(jìn)行更新,更新為True。

一開始想著按照id進(jìn)行更新,但是當(dāng)用戶多了以后id與網(wǎng)頁上顯示的id肯定不相同。

經(jīng)過我的苦苦思索,每個(gè)用戶中創(chuàng)建todo的時(shí)間肯定不相同,因此可以依據(jù)created_time可以進(jìn)行搜索,來對done進(jìn)行更新。

說干就干!

1、先查詢我們想要的那一條數(shù)據(jù)

用戶的todo顯示在網(wǎng)頁上時(shí)是按照created_time進(jìn)行了排序,因此在更新的時(shí)候也按照created_time進(jìn)行排序,這樣子便不會(huì)出錯(cuò)。

user_id = UserProfile.objects.get(username=request.user) #獲取當(dāng)前登陸用戶的todo id(按照后臺(tái)的打印實(shí)際上為用戶名)
todo_query = UserTodo.objects.filter(user_email=user_id, done=False) #按照user_id、done進(jìn)行對數(shù)據(jù)庫的篩選
#在UserTodo表中找出user_id以及該用戶下done=False的數(shù)據(jù)
#todo_query的類型為<class 'django.db.models.query.QuerySet'>
todo_query = todo_query.order_by("created_time") # 按照截至日期按照從小到大的順序進(jìn)行篩選,若要從大到小排序則("-created_time")

現(xiàn)在的結(jié)果是我們已經(jīng)得到了該用戶名下的所有done=False的數(shù)據(jù),并且已經(jīng)完成了排序

接下來就是找到我們想要的那一條數(shù)據(jù)

todo_dict = todo_query.values("created_time") #經(jīng)過values,得到created_time的那一列數(shù)據(jù)

類型依舊為QuerySet,但只有一種數(shù)據(jù),即全部是created_time的數(shù)據(jù),這時(shí)就可以提取我們想要的數(shù)據(jù)了

time_dict[3]['created_time'] #QuerySet中第四個(gè)名稱為created_time的數(shù)據(jù)(序號(hào)從0開始,因此3是第四個(gè))3為網(wǎng)頁上元素的索引
打印print(time_dict[3]['created_time'])的結(jié)果為:2018-06-07 01:45:10.938825+00:00

到此已經(jīng)完成數(shù)據(jù)的查詢。

2、對數(shù)據(jù)進(jìn)行更新

已經(jīng)是小菜一碟了hiahiahia。。。

按照上述查詢到的created_time,來找出當(dāng)前用戶下符合這一個(gè)cteated_time 的記錄(肯定只有一條)

time_index = time_dict[id]['created_time'] #id為從前端傳過來的網(wǎng)頁上元素的id
User = UserTodo.objects.get(user_id=user_id,created_time=time_index)
User.done = True
User.save()

Done!

以上這篇Django對數(shù)據(jù)庫進(jìn)行添加與更新的例子就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在python里從協(xié)程返回一個(gè)值的示例

    在python里從協(xié)程返回一個(gè)值的示例

    今天小編就為大家分享一篇在python里從協(xié)程返回一個(gè)值的示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • Python使用Paramiko控制linux第三方庫

    Python使用Paramiko控制linux第三方庫

    這篇文章主要介紹了Python使用Paramiko控制linux第三方庫,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • python詞云庫wordCloud使用方法詳解(解決中文亂碼)

    python詞云庫wordCloud使用方法詳解(解決中文亂碼)

    這篇文章主要介紹了python詞云庫wordCloud使用方法詳解(解決中文亂碼),需要的朋友可以參考下
    2020-02-02
  • turtle的基礎(chǔ)使用之python?turtle遞歸繪圖

    turtle的基礎(chǔ)使用之python?turtle遞歸繪圖

    這篇文章主要介紹了turtle的基礎(chǔ)使用之python?turtle遞歸繪圖,turtle是一種比較簡單的第三方庫,下面借助遞歸繪圖詳細(xì)描述該內(nèi)容,具有一的的知識(shí)性參考價(jià)值,需要的朋友可以參考一下
    2022-02-02
  • python導(dǎo)入不同目錄下的自定義模塊過程解析

    python導(dǎo)入不同目錄下的自定義模塊過程解析

    這篇文章主要介紹了python導(dǎo)入不同目錄下的自定義模塊過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • python實(shí)現(xiàn)矩陣的示例代碼

    python實(shí)現(xiàn)矩陣的示例代碼

    本文主要介紹了python實(shí)現(xiàn)矩陣的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • python?查看cpu的核數(shù)實(shí)現(xiàn)

    python?查看cpu的核數(shù)實(shí)現(xiàn)

    這篇文章主要介紹了python?查看cpu的核數(shù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python超有用的多版本管理工具pyenv

    Python超有用的多版本管理工具pyenv

    使用不同的Python版本,如果我們把需要的不同版本的Python都下載到服務(wù)器上,管理起來會(huì)非常困難,多版本并存又容易互相干擾,接下來就來介紹一個(gè)Python環(huán)境管理工具:pyenv,就可輕松的在多個(gè)版本的Python之間自由切換,需要的朋友可以參考下
    2021-09-09
  • Python中命令行參數(shù)argparse模塊的使用

    Python中命令行參數(shù)argparse模塊的使用

    argparse是python自帶的命令行參數(shù)解析包,可以用來方便的服務(wù)命令行參數(shù)。本文將通過示例和大家詳細(xì)講講argparse的使用,需要的可以參考一下
    2023-02-02
  • 深入了解Python如何操作MongoDB

    深入了解Python如何操作MongoDB

    MongoDB是由C++語言編寫的非關(guān)系型數(shù)據(jù)庫,是一個(gè)基于分布式文件存儲(chǔ)的開源數(shù)據(jù)庫系統(tǒng)。本文主要介紹了如何通過Python操作MongoDB,需要的可以參考一下
    2022-01-01

最新評(píng)論