ORM
ORM是什么?:(在django中,根据代码中的类自动生成数据库的表也叫--code first)
ORM:Object Relational Mapping(关系对象映射)
类名对应------》数据库中的表名
类属性对应---------》数据库里的字段
类实例对应---------》数据库表里的一行数据
obj.id obj.name.....类实例对象的属性
Django orm的优势:
Django的orm操作本质上会根据对接的数据库引擎,翻译成对应的sql语句;所有使用Django开发的项目无需关心程序底层使用的是MySQL、Oracle、sqlite....,如果数据库迁移,只需要更换Django的数据库引擎即可;
创建数据库类
models.py
#导包导入django数据库类
from django.db import models
#建立数据库类
class User(models.Model):
#主键 通过参数声明主键
id = models.IntegerField(primary_key=True)
#用户名 字符串类型需要声明长度限制
username = models.CharField(max_length=200)
#密码
password = models.CharField(max_length=100)
#时间字段
time = models.DateTimeField()
#图片
img = models.CharField(max_length=200)
#性别
gender = models.IntegerField()
#声明表名
class Meta:
#必须和数据库中的表名吻合
db_table = "user"
#查询全部数据
res = User.objects.all()
#print(res)
#查询限定条件的数据
res = User.objects.filter(username='新用户',password='你好')
#print(res)
#只取一条
res_one = User.objects.get(id=1)
#print(res_one)
#排除条件
res = User.objects.exclude(username='新用户')
#定制字段显示
res_s = User.objects.filter(username='新用户').values('password')
#排序
res = User.objects.filter(username='新用户').order_by("password").reverse()
#去重
res_dis = User.objects.filter(username='新用户').values('username').distinct()
#print(res_dis)
#取数量
res_count = User.objects.filter(username='新用户').count()
print(res_count)
#入库操作(增)
#建立实例
#user = User(username='新用户',password='你好')
#入库操作
#user.save()
#删除数据(删)
#User.objects.filter(username='新用户').delete()
#修改数据(改) 第一种方式
#user = User.objects.get(id=9)
#修改字段
#user.username = '1234'
#保存修改
#user.save()
#修改数据(改) 第二种方式
#return HttpResponse('',status=403)
#User.objects.filter(id=9).update(password='新密码')
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!