亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

如何使用django orm模塊中的is_delete

發布時間:2020-07-23 10:20:08 來源:億速云 閱讀:154 作者:小豬 欄目:開發技術

這篇文章主要講解了如何使用django orm模塊中的is_delete,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

數據庫刪除數據咱都知道,簡單的說就是當一條數據對企業沒用后,一般人可能會選擇刪除這條數據。

但是刪除后,萬一以后又突然有用呢。所以我們這時候會選擇在寫orm模塊的時候,加入is_delete字段

is_delete = models.BooleanField(default=False,verbose_name='是否刪除')

這樣以后咱如果要刪除一條數據了,就設置一下

is_delete=1

就表示這條數據在邏輯上刪除了,簡單的說就是你再怎么搜數據庫也搜不到了,如果以后還用,就再設置

is_delete=0

就可以了!

補充知識:django中當model設置了ordering后,使用distinct()和annotate()問題記錄

model類如下,我在class Meta中設置了ordering = ['-date_create'],即模型對象返回的記錄結果集是按照這個字段排序的。

class SystemUserPushHistory(models.Model):
 
  id = models.UUIDField(default=uuid.uuid4, primary_key=True)
  host_name = models.CharField(max_length=128, null=False)
  system_username = models.CharField(max_length=128, null=False)
  method = models.CharField(max_length=32, null=False)
  is_success = models.BooleanField(default=False)
  date_create = models.DateTimeField(auto_now_add=True, editable=False)
  message = models.CharField(max_length=4096, null=True)
 
  class Meta:
    db_table = "assets_systemuser_push_history"
    ordering = ['-date_create']
 
  def __str__(self):
    ret = self.system_username + " => " + self.host_name
    return ret

當業務有需求如對host_name進行分組顯示,在代碼中用到了annotate,如下。

>>> from django.db.models import Count 
>>> from assets.models import SystemUserPushHistory
>>> p = SystemUserPushHistory.objects.values("host_name").annotate(dcount=Count(1))
>>> p
<QuerySet [{'host_name': '點2', 'dcount': 1}, {'host_name': '點3', 'dcount': 2}, {'host_name': '點2', 'dcount': 1}, {'host_name': '點3', 'dcount': 1}]>
>>> print(p.query)
SELECT `assets_systemuser_push_history`.`host_name`, COUNT(1) AS `dcount` FROM `assets_systemuser_push_history` GROUP BY `assets_systemuser_push_history`.`host_name`, `assets_systemuser_push_history`.`date_create` ORDER BY `assets_systemuser_push_history`.`date_create` DESC

可以看到,所得到的結果并不像我們預期的一樣,之后把執行的sql輸出出來可以看到在group by的時候是對host_name和date_create進行分組,原因就是因為我們在model類中設置了ordering,去掉之后代碼運行正常。

使用distinct和上面的情況類似,就不列出來了。

看完上述內容,是不是對如何使用django orm模塊中的is_delete有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

根河市| 如皋市| 武夷山市| 五华县| 凤庆县| 镇平县| 资源县| 高邮市| 拉萨市| 南汇区| 紫阳县| 衡水市| 镇江市| 桐柏县| 临澧县| 麻栗坡县| 凉城县| 巢湖市| 望奎县| 赣州市| 阿拉善右旗| 溧水县| 四子王旗| 博野县| 文安县| 思茅市| 阳西县| 南昌县| 北辰区| 临武县| 平陆县| 楚雄市| 阿城市| 六枝特区| 扬州市| 镇雄县| 牙克石市| 兴义市| 循化| 威远县| 廊坊市|