Django 数据模型

一对一关系

学生和学生证关系

class Student(models.Model):
    sno = models.AutoField(primary_key=True)
    sname = models.CharField(max_length=30)

    def __unicode__(self):
        return u'Student:%s'%self.sname

class Scard(models.Model):
    stu = models.OneToOneField(Student,primary_key=True,on_delete=models.CASCADE)
    major = models.CharField(max_length=30,unique=True)

    def __unicode__(self):
        return u'Scard:%s'%self.major

#插入数据
s1 = Student.objects.create(sname='zhangsan')
s2 = Student.objects.create(sname='lisi')

Scard.objects.create(stu=s1,major='数学')
<Scard: [Bad Unicode data]>
Scard.objects.create(stu=s2,major='语文')
<Scard: [Bad Unicode data]>

#查询数据 正向查询 scard 为 models 里面的类,查询时候用类小写
Student.objects.first().scard
<Scard: Scard:数学>

#查新数据  逆向查询  stu 为 Scard类中的属性,也就是字段
Scard.objects.first().stu
<Student: Student:zhangsan>

一对多关系

班级和学生

#班级主表 一
class Clazz(models.Model):
    cno = models.AutoField(primary_key=True)
    cname = models.CharField(max_length=30)

    def __unicode__(self):
        return u'Clazz:%s'%self.cname

#学生表 从表 多
class Student(models.Model):
    sno = models.AutoField(primary_key=True)
    sname = models.CharField(max_length=30)
    cno = models.ForeignKey(Clazz,on_delete=models.CASCADE)

    def __unicode__(self):
        return u'Student:%s'%self.sname


from stu.models import *
# 插入数据
cls1 = Clazz.objects.create(cname='python')
cls2 = Clazz.objects.create(cname='html')

Student.objects.create(sname='zhangsan',cno=cls1)
<Student: Student:zhangsan>
Student.objects.create(sname='lisi',cno=cls1)
<Student: Student:lisi>
Student.objects.create(sname='wangwu',cno=cls2)
<Student: Student:wangwu>

#查询数据  正向查询  一个班级有多个学生
Clazz.objects.first().student_set.all()
<QuerySet [<Student: Student:zhangsan>, <Student: Student:lisi>]>

# 查询数据 逆向查询 一个学生是属于一个班级
Student.objects.first().cno
<Clazz: Clazz:python>



写一个方法可以批量插入数据
def insertData1(clsname,*snames):
    try:
        cls = Clazz.objects.get(cname=clsname)
    except Clazz.DoesNotExist:
        cls = Clazz.objects.create(cname=clsname)
    for i in snames:
        try:
            stu = Student.objects.get(sname=i)
        except Student.DoesNotExist:
            Student.objects.create(sname=i,cno=cls)

#调用函数            
insertData1('k8s','zhangjie','xiena')


多对多关系

课程和教师

#课程表
class Course(models.Model):
    course_no = models.AutoField(primary_key=True)
    course_name = models.CharField(max_length=30)

    def __unicode__(self):
        return u'Course:%s'%self.course_name

#教师表
class Teacher(models.Model):
    tno = models.AutoField(primary_key=True)
    tname = models.CharField(max_length=30)
    cour = models.ManyToManyField(Course)

    def __unicode__(self):
        return u'Teacher:%s'%self.tname


# 课程表插入数据
course1 = Course.objects.create(course_name='Python')
course2 = Course.objects.create(course_name='Java')
course3 = Course.objects.create(course_name='Html5')

#教师表插入数据
t1 = Teacher.objects.create(tname='zhangsan')
t2 = Teacher.objects.create(tname='lisi')

#教师表插入课程 与一对多是有区别的
t1.cour.add(course1,course2,course3)

#正向查询 是集合列表
Course.objects.first().teacher_set.all()
<QuerySet [<Teacher: Teacher:zhangsan>]>

#逆向查询 也是集合列表
Teacher.objects.first().cour.all()
<QuerySet [<Course: Course:Python>, <Course: Course:Java>, <Course: Course:Html5>]>


#写一个方法可以批量插入数据:

def inserDataN(teachername,*coursename):
    try:
        t = Teacher.objects.get(tname=teachername)
    except Teacher.DoesNotExist:
        t = Teacher.objects.create(tname=teachername)
    for i in coursename:
        try:
            course = Course.objects.get(course_name=i)
        except:
            course = Course.objects.create(course_name=i)
            t.cour.add(course)   

# 方法调用       
inserDataN('dong','css','js')

posted @ 2020-12-25 11:01  lixinliang  阅读(92)  评论(0编辑  收藏  举报