Django QuerySet对象,all()方法

all()方法

在Django中,all()方法是QuerySet对象的一个方法,用于获取模型的所有实例。

当你调用ModelName.objects.all()时,Django会生成一个SQL查询,从数据库中获取该模型的所有记录,并返回一个QuerySet对象,这个对象包含了所有的模型实例。

相当于SQL语句中如:

select * from table_name


例如,如果你有一个Post模型,你可以这样获取所有的帖子:

from .models import Post
posts = Post.objects.all()

在这个例子中,posts是一个QuerySet对象,你可以像操作列表一样操作它,例如,你可以遍历它,获取它的长度,或者对它进行切片等操作。

需要注意的是,all()方法并不会立即从数据库中获取所有的记录,而是在你第一次访问QuerySet对象时才从数据库中获取记录。

这是Django的延迟查询机制,可以避免不必要的数据库查询,提高性能。


 

1,创建应用

Test/app11

python manage.py startapp app11

2,注册应用

Test/Test/settings.py

3,添加应用路由

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    # ...
    path('app11/', include('app11.urls')),
]

4,应用添加模型

Test/app11/models.py

from django.db import models

class Post(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    pub_date = models.DateTimeField('date published')

5,应用创建和执行迁移

# 创建迁移文件
python manage.py makemigrations app11

# 执行迁移文件
python manage.py migrate app11

6,应用添加视图

Test/app11/views.py

from django.shortcuts import render
from .models import Post

def index(request):
    posts = Post.objects.all()
    return render(request, '11/index.html', {'posts': posts})

7,应用添加html代码

Test/templates/11/index.html

<!-- posts/index.html -->

<h1>我的博客</h1>
{% for post in posts %}

<h2>{{ post.title }}</h2>
<h4>{{ post.content }}</h4>

<br/>
{% endfor %}

8,应用添加路由

Test/app11/urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('index/', views.index, name='index'),
]

9,应用添加数据

Test/create_posts.py

import os
import django

# 设置Django环境,需要指定settings模块
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "Test.settings")
django.setup()

from app11.models import Post
from datetime import datetime

# 创建并保存Post对象
post = Post(title="张国荣", content="(英语:Leslie Cheung Kwok Wing,1956年9月12日—2003年4月1日),本名张发宗,香港男歌手、演员、词曲作家[3],并曾经担任电影配乐、排舞、音乐视频导演、艺术总监和电影导演。", pub_date=datetime.now())
post.save()

# 或者使用objects.create()方法
Post.objects.create(title="梅艳芳", content="英语:Anita Mui Yim-fong;1963年10月10日—2003年12月30日),香港女歌手、演员、社会活动家,有“乐坛大姐大”之称。她的形象百变,获奖无数,是香港粤语流行乐坛辉煌鼎盛期的标志性人物,也是香港演艺界第一位同时取得“歌后”及“影后”级殊荣的女艺人。", pub_date=datetime.now())

10,访问页面

http://127.0.0.1:8000/app11/index/

相关推荐

  1. promise的all方法和race

    2024-07-09 23:20:03       45 阅读
  2. SAP ABAP 对象ALV的一些功能(ALV资料五)

    2024-07-09 23:20:03       38 阅读
  3. sqlalchemy expire_all 方法详解,强制刷新会话缓存

    2024-07-09 23:20:03       49 阅读
  4. 【Python】探索 Python 中的 any 和 all 方法

    2024-07-09 23:20:03       20 阅读
  5. Python笔记|列表对象方法

    2024-07-09 23:20:03       26 阅读
  6. 面向对象的开发方法

    2024-07-09 23:20:03       23 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-09 23:20:03       53 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-09 23:20:03       56 阅读
  3. 在Django里面运行非项目文件

    2024-07-09 23:20:03       46 阅读
  4. Python语言-面向对象

    2024-07-09 23:20:03       57 阅读

热门阅读

  1. TensorFlow 的基本概念和使用场景

    2024-07-09 23:20:03       19 阅读
  2. Perl 语言开发(七):哈希和关联数组

    2024-07-09 23:20:03       21 阅读
  3. Linux上web服务器搭建(Apache、Nginx)

    2024-07-09 23:20:03       18 阅读
  4. Apache tika 实现各种文档内容解析

    2024-07-09 23:20:03       27 阅读
  5. 优化:遍历List循环查找数据库导致接口过慢问题

    2024-07-09 23:20:03       24 阅读
  6. Linux C++ 046-设计模式之策略模式

    2024-07-09 23:20:03       25 阅读
  7. 2024年二级建造师考试题库及答案

    2024-07-09 23:20:03       24 阅读