2011-07-13 17:35:51 +08:00
|
|
|
from django.db import models
|
2006-06-07 08:09:29 +08:00
|
|
|
|
2011-10-14 02:04:12 +08:00
|
|
|
|
2006-06-07 08:09:29 +08:00
|
|
|
class Person(models.Model):
|
2018-08-01 17:52:28 +08:00
|
|
|
first_name = models.CharField(max_length=100, unique=True)
|
2007-08-05 13:14:46 +08:00
|
|
|
last_name = models.CharField(max_length=100)
|
2006-06-07 08:09:29 +08:00
|
|
|
birthday = models.DateField()
|
2015-06-05 07:27:10 +08:00
|
|
|
defaults = models.TextField()
|
2006-06-07 08:09:29 +08:00
|
|
|
|
2013-05-25 04:36:09 +08:00
|
|
|
|
|
|
|
class DefaultPerson(models.Model):
|
|
|
|
first_name = models.CharField(max_length=100, default="Anonymous")
|
|
|
|
|
|
|
|
|
2008-09-03 08:09:33 +08:00
|
|
|
class ManualPrimaryKeyTest(models.Model):
|
|
|
|
id = models.IntegerField(primary_key=True)
|
|
|
|
data = models.CharField(max_length=100)
|
2013-04-28 23:15:41 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Profile(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
person = models.ForeignKey(Person, models.CASCADE, primary_key=True)
|
2013-05-19 20:15:36 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Tag(models.Model):
|
2013-05-20 04:58:58 +08:00
|
|
|
text = models.CharField(max_length=255, unique=True)
|
2013-05-19 20:15:36 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Thing(models.Model):
|
2017-05-10 23:33:46 +08:00
|
|
|
name = models.CharField(max_length=255)
|
2013-05-19 20:15:36 +08:00
|
|
|
tags = models.ManyToManyField(Tag)
|
2014-04-21 18:12:09 +08:00
|
|
|
|
2017-05-19 18:40:43 +08:00
|
|
|
@property
|
|
|
|
def capitalized_name_property(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
@capitalized_name_property.setter
|
|
|
|
def capitalized_name_property(self, val):
|
|
|
|
self.name = val.capitalize()
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name_in_all_caps(self):
|
|
|
|
return self.name.upper()
|
|
|
|
|
2014-04-21 18:12:09 +08:00
|
|
|
|
|
|
|
class Publisher(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
|
|
|
|
|
|
|
class Author(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
|
|
|
|
|
|
|
class Book(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
authors = models.ManyToManyField(Author, related_name="books")
|
2015-07-22 22:43:21 +08:00
|
|
|
publisher = models.ForeignKey(
|
|
|
|
Publisher,
|
|
|
|
models.CASCADE,
|
|
|
|
related_name="books",
|
|
|
|
db_column="publisher_id_column",
|
|
|
|
)
|