首页 > 其他分享 >Django-ORM

Django-ORM

时间:2022-10-22 23:33:10浏览次数:43  
标签:username name models Django -- ORM password id

目录

-定义

-使用方法

--models.py

--数据库迁移命令 

-- 注意

-实际操作

--ORM实现字段的增删改查

--ORM实现数据的增删改查

--ORM创建表与表之间的联系


-定义

ORM:对象关系映射

作用:让不懂SQL语句的人也能通过写python代码操作数据库

优势:操作语法简单,提高开发效率

不足:封装程度高,有时SQL语句效率低,需要自己写

ORM会将写的类映射成表,对象映射成记录,对象属性=》某个字段

-使用方法

--models.py

1、去应用文件夹下的model.py中写类,必须继承model.Model

class userinfo02(models.Model):
    id = models.AutoField(primary_key = True, verbose_name = '主键')  # verbose_name字段的解释信息
    # id int primary_key auto_increment
    name = models.CharField(max_length=16, verbose_name= '姓名')
    # name varchar(16) 必须指定max_length
    password = models.IntegerField(verbose_name= '密码')
    # password int

--数据库迁移命令 

2、数据库迁移命令

python manage.py makemigrations
# 自动将迁移记录记录到应用文件夹下的migrations文件夹下

 

但此时还未在MySQL中创建,还需执行以下命令↓ 

python manage.py migrate
# 真正在MySQL中创建数据库,且一次性会产生很多表

 

 

 有些是Django默认产生的表,我们自己创建的表会自动加上app名前缀,以便区分

-- 注意

只要修改了model.py文件下的有关数据库的数据/代码,就必须重写执行数据库迁移命令,没有捷径

-实际操作

--ORM实现字段的增删改查

1、字段的增

直接在类下增加字段代码即可,但倘若一些字段已经有值了而去新增字段:

①在终端选择提供默认值

        

         选择1,然后回车后叫你输入默认值,比如输入18,则迁移后会在数据库中看到字段增加了age且默认值为18

②直接设置字段参数null = True

        info = models.CharField(max_length=32, verbose_name='简介', null=True

 ③直接设置字段的默认值

        hobby = models.CharField(max_length=16, verbose_name='爱好', default='study')

2、字段的删

就把类下的字段注释掉或删掉,再执行数据库迁移命令即可

但删掉后字段的数据就没了,所以一定要细心,不要随意删或注释

3、字段的改

直接在类下修改字段即可,不过改完一定执行数据库迁移命令

4、字段的查

随便看呗 

--ORM实现数据的增删改查

1、数据的增

# 第一种方式
models.userinfo02.objects.create(name=username, password=password)
 
# 第二种方式
user_obj = models.userinfo02(name=username, password=password)
user_obj.save()
 
# example-注册
def reg(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
      from App01 import models  # 必不能忘
        # 第一种方式↓
        # res = models.userinfo02.objects.create(name=username, password=password)
        # print(res, res.name, res.password)
         # 第二种方式↓
        user_obj = models.userinfo02(name=username, password=password)
        user_obj.save()
        return HttpResponse('注册成功')
    return render(request, 'html05 register_and_mysql.html')

2、数据的删

# 拿到要删除的对象id
delete_id = request.GET.get('user_id')
# 删除数据
models.userinfo02.objects.filter(id=delete_id).delete()
"""
上述↑代码其实可以批量删除 当传入id多时
"""

3、数据的改

# 修改数据方式1  
models.userinfo02.objects.filter(id=user_id).update(name=name, password=password)
"""可批量更新 当传入id多个时"""
 
# 修改数据方式2
data_querySet = models.userinfo02.objects.filter(id=user_id).first()
data_querySet.name = name
data_querySet.password = password
data_querySet.save()

4、数据的查

def login(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        # print(username, password)
        from App01 import models   # 最好写在最上面,这是为了介绍
        """
        res = models.userinfo02.objects.filter(name = username, password=password)
        # 等价于select * from userinfo02 where name = username and password = password
        # print(res)
        user_obj = res[0]  # 返回一个列表套数据对象[数据对象1,数据对象2,…],用索引0取该对象 但不支持负索引
        """
        user_obj = models.userinfo02.objects.filter(name=username, password=password).first()     # 直接调用封装好的方法得到该对象
        if user_obj.name == username:
            if user_obj.password == password:
                return HttpResponse('登录成功')
            else:
                return HttpResponse('密码错误')
        else:
            return HttpResponse('用户不存在')
    return render(request, 'html04 login_and_mysql.html')

--ORM创建表与表之间的联系

创建表关系,先将基表创建出来,然后再添加外键字段

class Book(models.Model):
    title = models.CharField(max_length=32)
    price = models.DecimalField(max_digits=5, decimal_places=2) # 总共5位,小数占2位
    # 外键字段
    publish = models.ForeignKey(to='Publish', on_delete=models.CASCADE)
    '''
    图书和出版社是一对多,外键字段写在多的一方
    默认就是和出版社表的主键字段做关联
    如果字段对应的是ForeignKey,那么orm会自动在字段后面加_id,后面我们在定义ForeignKey时就不要加_id
    '''
    authors = models.ManyToManyField(to='Author')
    '''
    图书和作者多对多,外键推荐写在查询频率高的一方
    authors是一个虚拟字段,用于告诉orm是多对多关系,orm自动帮你创建第三章表
    '''
 
class Publish(models.Model):
    name = models.CharField(max_length=32)
    address = models.CharField(max_length=64)
 
class Author(models.Model):
    name = models.CharField(max_length=32)
    age = models.IntegerField()
    # 外键字段
    author_detail = models.OneToOneField(to='AuthorDetail', on_delete=models.CASCADE)
    '''
    作者与作者详情表是一对一关系,外键字段推荐建在查询频率高的一方
    OneToOneField也会自动给外键字段加_id后缀
    '''
 
class AuthorDetail(models.Model):
    phone = models.CharField(max_length=11)
    address = models.CharField(max_length=32)
    email_add = models.EmailField()

 

 

标签:username,name,models,Django,--,ORM,password,id
From: https://www.cnblogs.com/weer/p/16817608.html

相关文章

  • Django-入门
    目录-Django版本--5种转换器--自定义转换器--级联更新级联删除-Django安装-Django基本操作--终端命令操作---创建Django项目---启动Django项目---创建功能模块......
  • element-ui form表单的input框按回车键后提交表单的问题
    在项目中,经常有表单提交操作,当提交的表单只有一行且均有必填校验时,按回车键会执行form的submit,但这个submit并不一定是我们想要的,因此要想办法避免此问题避免方法:通过在f......
  • C# 输入法切换 C#中FormClosing与FormClosed的区别详细解析
    引用///<summary>///输入法切ENG///</summary>publicvoidChangeENG(){WinAPI.PostMessage(WinAPI.HWND_BROADC......
  • django 前戏
    python三大主流web框架"""django特点:大而全自带的功能特别特别特别的多类似于航空母舰不足之处:有时候过于笨重flask特点:小而精自带的功能特别特别特别的少......
  • Matlab_normpdf
    >>x=normrnd(15,5,1000,1);>>hist(x)>>x2=rand(1000,1);>>hist(x2,50)>>hist(x,50)>>y=normrnd(15,1,1000,1);>>figure;hist(y,50)>>x=0:30;>>pdf=normp......
  • Normal Matrix(法向量变换矩阵)
    我们都知道gl的坐标系统。它的工作是将坐标从一个坐标系转到另一个坐标系。其中我们用到了几个转换矩阵。其中最为重要的是模型(Model)、视图(View)、投影(Projection)三个矩阵。......
  • Django之同时新增数据到两个数据库表与同时返回两个表的数据(插拔式)
    models:比如有以下三个模型fromdjango.dbimportmodels"""基类,其他类继承即可获得对应的字段"""classBaseModel(models.Model):updated_tm=models.DateT......
  • django--各个文件的含义
    当你创建项目或者应用后你是不是发现多了很多个文件,现在我们来看看各代表什么意思与你项目名相同的文件夹:是项目的管理功能目录,这个目录的名称因用户所创建的项目名称的不......
  • transform 进阶
    1、ApplyMethod这个只能执行mobject的方法,例如:s=Square()sp(ApplyMethod(s.scale,3)) 2、ApplyPointwiseFunctions=Squa......
  • 【工具】1245- Formily:阿里高性能表单解决方案
    加强自身学习,提高自身素质。积累工作经验,改进工作方法,向周围同志学习,注重别人优点,学习他们处理问题的方法,查找不足,提高自己。hi,大家好,我是小智,今天又到了我们的分享时......