ORM表关系及操作

ORM表关系及操作

多对一关系

多对一关系是什么

Django使用django.db.models.ForeignKey`定义多对一关系。

class Employee(models.Model):
    emp_name = models.CharField(max_length=20,verbose_name="姓名")
    job = models.CharField(max_length=20,verbose_name="职位")
    salary = models.IntegerField(verbose_name="工资")
    department = models.ForeignKey(to=Department,on_delete=models.CASCADE,verbose_name="部门")

多对一关系的增删改操作

增
    def post(self,request):
        name = request.POST.get('dep_name')
        desc = request.POST.get('desc')
        try:
            Department.objects.create(dep_name=name,desc=desc)
        except Exception as e:
            print(e)
            return HttpResponse("添加失败")
        return redirect('/index/')class DelView(View):
    def get(self,request,id):
        Employee.objects.filter(id=id).delete()
        return redirect('/index/')class UpdateView(View):
    def get(self,request,id):
        emp_date=Employee.objects.get(id=id)
        return render(request,'update.html',{'emp':emp_date})
    def post(self,request,id):
        name = request.POST.get('emp_name')
        job = request.POST.get('job')
        salary = request.POST.get('salary')
        department = request.POST.get('department')
        try:
            Employee.objects.filter(id=id).update(
                emp_name=name,
                job=job,
                salary=salary,
                department=department,
            )
        except Exception as e:
            print(e)
            return HttpResponse("修改失败")
        return redirect('/index/')

多对一的正向查询

# 查询id为2的学生的老师姓名
	--找到id为2的学生
    stu = Student.objects.get(id=2)
    --找到stu对应的老师    stu.teacher.name
    stu.外键.name

多对一的反向查询

反向查询:通过django的内置属性来进行查询  模型类(模型类小写)_set()可以反向查询老师名下的所有学生,
    # 查询id为1的老师的所有学生    --先找到id为1的老师    
    tea = Teacher.objects.get(id=1)    
    --查询tea老师名下的所有学生  老师对象.模型类_set.all()    
    tea.student_set.all()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值