浅谈Django中的数据库模型类-models.py(一对一的关系)
如下所示:
#-*-coding:utf-8-*- from__future__importunicode_literals fromdjango.dbimportmodels #Createyourmodelshere. #一对一关系:数据库中两个表中数据的对应关系 #一个账户对应着一个联系人,而一个联系人有一个账户 #一对一关系是通过在两个表之间定义相同的主键来完成 classAccount(models.Model): username=models.CharField(max_length=20,null=True,blank=True,verbose_name=u'用户名') password=models.CharField(max_length=40,null=True,blank=True,verbose_name=u'密码') register_date=models.DateField(auto_now_add=True,null=True,blank=True,verbose_name=u'注册时间') classMeta: db_table='Account' #该函数是负责展示该类对象的详细信息的函数,根据需要自定义展示的内容 def__unicode__(self): return'Account:%s'%self.username classContact(models.Model): #在Contact中,关联Account表,让两个表的数据产生联系 #第一个参数:是被关联的模型名称 #第二个参数:当Account中的一条数据被删除的时候,与之对应的Contact数据也会被删除 account=models.OneToOneField(Account,on_delete=models.CASCADE,primary_key=True) address=models.CharField(max_length=100,null=True) code=models.CharField(max_length=20,null=True) mobile=models.CharField(max_length=20,null=True) classMeta: db_table='Contact' def__unicode__(self): #self.account:通过联系人对象反向查询该信息所属的人 return'Contact:%s-%s-%s'%(self.account.username,self.address,self.mobile) #ORM:关系映射对象,把传统的SQL语句封装成了类和对象的形式,在操作表中的数据记录时,就像在操作类和对象 #一对一的正向查询和反向查询 a1=Account(username='dawei',password='333') a1.save() c1=Contact(account=a1,address='xinmi',code='450000',mobile='13212344321') c1.save() printa1.contact#正向查询,通过账户查询该账户对应的详细信息 printc1.account#反向查询,通过详细信息查询信息对应的账户 #a1.contact.mobile #a1.contact.address #a1.contact.code #c1.account.username #c1.account.password #删除账户,对应的联系人信息也会被删除 #a1.delete()
以上这篇浅谈Django中的数据库模型类-models.py(一对一的关系)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。