溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django對數據庫進行添加與更新的例子

發(fā)布時間:2020-10-03 23:40:28 來源:腳本之家 閱讀:150 作者:Lex_lht 欄目:開發(fā)技術

先把models.py擺這兒

#models.py
class UserProfile(AbstractUser):
 '''
 繼承Django的AbstractUser 并向里面添加兩條數據內容懷疑
 '''
 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 #指定模型的復數形式是什么,如果不指定Django會自動在模型名稱后加一個's'
 
class UserTodo(models.Model):
 created_time = models.DateTimeField(default=datetime.now(),verbose_name='創(chuàng)建時間')
 user_id = models.ForeignKey(UserProfile,on_delete=models.C ASCADE) #設置外鍵,關聯到UserProfile表
 # models.CASCADE表示若刪除某一用戶,則該用戶下的所有UserTodo也會被刪除
 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

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

完成model后,在Terminal運行python manage.py makemigrations 生成數據庫。然后可以進行保存操作

對于沒有沒有外鍵的數據庫:

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重新編碼技術,存儲在數據庫中
user_profile.is_active = True #判斷用戶是否激活
user_profile.save()

有外鍵的數據庫

1、首先應先獲取關聯的數據庫的信息,如果為用戶則為用的在數據庫中的ID

user_id = UserProfile.objects.get(username=request.user) #request.user表示當前登陸的用戶名稱,后臺實際上是用戶名

2、保存到數據庫中

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

二、對數據庫進行更新及查詢的操作

動機是當用戶點擊網頁上的X號是對數據庫中的done進行更新,更新為True。

一開始想著按照id進行更新,但是當用戶多了以后id與網頁上顯示的id肯定不相同。

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

說干就干!

1、先查詢我們想要的那一條數據

用戶的todo顯示在網頁上時是按照created_time進行了排序,因此在更新的時候也按照created_time進行排序,這樣子便不會出錯。

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

現在的結果是我們已經得到了該用戶名下的所有done=False的數據,并且已經完成了排序

接下來就是找到我們想要的那一條數據

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

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

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

到此已經完成數據的查詢。

2、對數據進行更新

已經是小菜一碟了hiahiahia。。。

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

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

Done!

以上這篇Django對數據庫進行添加與更新的例子就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI