django内置数据库常用查询

本文详细介绍了Django ORM的各种查询方法,包括获取所有数据、条件过滤、排除条件、排序、限制返回字段、获取单个对象、统计查询条件的总条数、检测数据存在性、分页查询等,以及各种查询条件的使用,如大于、小于、包含、模糊查询、判断是否为null、年月日运算、或条件等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# 如果获取不到符合条件的数据,会返回空的查询集也叫结果集  <QuerySet []>


# 惰性查询,需要的时候才去查询,如果不需要则不会执行查询,


# 在使用,if,序列化,迭代时,会对查询集合求值


# 查询数据对象的集合,叫做查询集或结果集,如下:
# <QuerySet [<Users: Users object>, <Users: Users object>, <Users: Users object>]>


如果返回使用str魔术方法,那么会返回这样的查询集
def __str__(self):
	return self.username
    #return '名字:'+self.username+'年龄:'+self.sex
<QuerySet [<Users: 哒哒>, <Users: 嘟嘟>, <Users: 滴滴>]>
#<QuerySet [<Users: 名字:哒哒;年龄:20>, <Users: 嘟嘟;年龄:20>, <Users: 滴滴;年龄:20>]>


# 获取User数据库,所有的数据
# data = Users.objects.all()
# <QuerySet [<Users: Users object>, <Users: Users object>, <Users: Users object>]>


# 尽量不使用此查询方式,上面把值赋给一个变量,可复用,而下面这个,每用一次就要查询一次,徒增开销
for i in User.objects.all()
	pass
for i in User.objects.all()
    pass


# 条件过滤 filter()  要sex=0的数据
data = Users.objects.filter(sex=0)
data = Users.objects.filter(sex=0,age=22)
data = Users.objects.filter(sex=0).filter(age=26)


# 条件排除 exclude()  就是不要sex=0的数据  
data = Users.objects.exclude(sex=0)


# 排序 order_by()  对查询出来的数据以order_by对id进行排序
data = Users.objects.all().order_by('-id')


# values() 一个对象构成一个字典,然后构成一个列表返回,限制返回的字段
data = Users.objects.all().values()


# 这里只返回id,username,age字段
data = Users.objects.all().values('id','username','age')


# get() 获取一个对象
data = Users.objects.get(id=1)
# 返回的是一个对象,不再是一个查询集,
'''
get如果查询不到符合条件的数据 则抛出异常 DoesNotExist at /demo/   Users matching query does not exist.
get如果查询到多条数据,抛出异常 MultipleObjectsReturned at /demo/ get() returned more than one Users -- it returned 2!
'''


# count() 统计并返回查询条件的总条数
# data = Users.objects.all()
# print(data.count())


# first last
# first 返回符合条件的第一个对象
# last  返回符合条件的最后一个对象
# data = Users.objects.filter(sex=0).first()


# exists() 检测查询条件的数据是否存在  返回 True 或 False
# data = Users.objects.filter(sex=2).exists()


# 数据库limit的用法,不支持负数索引 [0] = [0:1],如果查询为空,就会报错
# 使用下标返回一个新的查询集
#从0开始,取5条
data = Users.objects.filter(sex=0)[:5]
# 跳过前五条,去除后面的10条
data = Users.objects.filter(sex=0)[5:10]

# django中where查询  frlter() exclude() get() 加参数进行where 进行查询


# 比较运算符 大于号=gt  小于号=lt 
# data = Users.objects.filter(age__gt=20)
# gt,gte,lt,lte : 大于,大于等于,小于,小于等于

#包含查询  like 模糊查询 contains严格区分大小写搜索 icoontainsb不区分大小写搜索
# select * from user where name like '%admin%';
# data = Users.objects.filter(username__contains='a')
# data = Users.objects.filter(username__icontains='a')


# startswith  查询以'a'开头的,大小写敏感
# data = Users.objects.filter(username__startswith='a')
# endwith     查询以'a'结尾的,大小写敏感
# data = Users.objects.filter(username__endwith='a')


isnull,isnotnull 判断是否为null
filter(a___isnull=False)

# in
# select * from user where id in 1,23
# 条件id包含1和23的
data = Users.objects.filter(id__in=[1,23])


#year,month,day,hour,minute,second:对日期类型的属性进行运算
filter(times__year=1960)


# or
# select * from users where username like '%ab%' or age like '%ab%' or email like '%ab%';
filter(Q(条件)|Q(条件))
# from django.db.models import Q
# data = Users.objects.filter(Q(username__contains='ab')|Q(age__contains='ab')|Q(email__contains='ab'))
# print(data)

docsdjangoproject.com/een/1.1



### Django 5 数据库配置与使用 Django 是一个功能强大的 Web 框架,内置了对多种数据库的支持。默认情况下,Django 使用 SQLite 作为其默认数据库[^1]。然而,对于生产环境或需要更复杂功能的项目,通常会使用 MySQL、PostgreSQL 等关系型数据库。 #### 1. 默认数据库配置(SQLite) 在创建一个新的 Django 项目时,`settings.py` 文件中已经包含了 SQLite 的初始配置。以下是一个典型的 SQLite 配置示例: ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } ``` SQLite 是一种轻量级的嵌入式数据库,适合用于开发和测试阶段[^1]。它不需要单独的服务器进程或系统配置,因此非常方便。 #### 2. 配置 MySQL 数据库 如果需要将 Django 项目连接到 MySQL 数据库,可以通过修改 `settings.py` 文件中的 `DATABASES` 配置来实现。以下是 MySQL 数据库的典型配置示例: ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'database_demo', # 数据库名称 'USER': 'root', # 数据库用户名 'PASSWORD': 'password', # 数据库密码 'HOST': '127.0.0.1', # 数据库主机地址 'PORT': '3306', # 数据库端口号 'OPTIONS': { 'charset': 'utf8mb4', # 指定字符集以支持中文和其他特殊字符 'init_command': "SET sql_mode='STRICT_TRANS_TABLES'", }, } } ``` 注意:为了确保数据库能够正确存储中文字符,建议在 `OPTIONS` 中指定字符集为 `utf8mb4`[^4]。 #### 3. 安装必要的依赖 在使用 MySQL 数据库之前,需要安装 Python 的 MySQL 驱动程序。可以使用以下命令安装 `mysqlclient` 或 `pymysql`: ```bash pip install mysqlclient ``` 或者,如果遇到安装问题,可以尝试使用 `PyMySQL` 并进行如下配置: ```python import pymysql pymysql.install_as_MySQLdb() ``` #### 4. 迁移数据库 完成数据库配置后,需要通过 Django 提供的迁移工具将模型同步到数据库中。以下是常用的迁移命令: ```bash python manage.py makemigrations python manage.py migrate ``` 这些命令会根据项目的模型定义生成并应用数据库迁移文件[^3]。 #### 5. 数据库操作 Django 提供了 ORM(对象关系映射)工具,允许开发者以面向对象的方式操作数据库。以下是一些常见的数据库操作示例: - **创建数据** ```python from myapp.models import MyModel obj = MyModel(field1="value1", field2="value2") obj.save() ``` - **查询数据** ```python # 获取所有记录 objects = MyModel.objects.all() # 根据条件过滤 filtered_objects = MyModel.objects.filter(field1="value1") ``` - **更新数据** ```python obj = MyModel.objects.get(id=1) obj.field1 = "new_value" obj.save() ``` - **删除数据** ```python obj = MyModel.objects.get(id=1) obj.delete() ``` 以上是 Django 数据库的基本配置与使用方法。通过合理配置和使用 ORM 工具,可以高效地管理项目中的数据[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值