2020-07-18 11:17:39 +00:00
|
|
|
from django.db import connection, models
|
2022-04-16 13:29:51 +00:00
|
|
|
from django.db.models.functions import Lower
|
2023-06-01 14:39:52 +00:00
|
|
|
from django.utils.functional import SimpleLazyObject
|
2011-01-24 14:58:05 +00:00
|
|
|
|
2011-01-24 15:18:56 +00:00
|
|
|
|
|
|
|
class People(models.Model):
|
|
|
|
name = models.CharField(max_length=255)
|
2022-02-03 19:24:19 +00:00
|
|
|
parent = models.ForeignKey("self", models.CASCADE)
|
2011-01-24 15:18:56 +00:00
|
|
|
|
2013-11-03 04:36:09 +00:00
|
|
|
|
2011-01-24 15:18:56 +00:00
|
|
|
class Message(models.Model):
|
2022-02-03 19:24:19 +00:00
|
|
|
from_field = models.ForeignKey(People, models.CASCADE, db_column="from_id")
|
2022-07-04 18:28:44 +00:00
|
|
|
author = models.ForeignKey(People, models.CASCADE, related_name="message_authors")
|
2012-02-05 07:51:37 +00:00
|
|
|
|
2013-11-03 04:36:09 +00:00
|
|
|
|
2012-02-05 07:51:37 +00:00
|
|
|
class PeopleData(models.Model):
|
2015-07-22 14:43:21 +00:00
|
|
|
people_pk = models.ForeignKey(People, models.CASCADE, primary_key=True)
|
2012-02-05 07:51:37 +00:00
|
|
|
ssn = models.CharField(max_length=11)
|
|
|
|
|
2013-11-03 04:36:09 +00:00
|
|
|
|
2012-02-05 07:51:37 +00:00
|
|
|
class PeopleMoreData(models.Model):
|
2015-07-22 14:43:21 +00:00
|
|
|
people_unique = models.ForeignKey(People, models.CASCADE, unique=True)
|
2016-12-13 11:38:09 +00:00
|
|
|
message = models.ForeignKey(Message, models.CASCADE, blank=True, null=True)
|
2012-02-05 07:51:37 +00:00
|
|
|
license = models.CharField(max_length=255)
|
|
|
|
|
2013-11-03 04:36:09 +00:00
|
|
|
|
2021-10-30 15:08:06 +00:00
|
|
|
class ForeignKeyToField(models.Model):
|
|
|
|
to_field_fk = models.ForeignKey(
|
2022-02-03 19:24:19 +00:00
|
|
|
PeopleMoreData,
|
|
|
|
models.CASCADE,
|
|
|
|
to_field="people_unique",
|
2021-10-30 15:08:06 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2012-02-11 20:53:48 +00:00
|
|
|
class DigitsInColumnName(models.Model):
|
2022-02-03 19:24:19 +00:00
|
|
|
all_digits = models.CharField(max_length=11, db_column="123")
|
|
|
|
leading_digit = models.CharField(max_length=11, db_column="4extra")
|
|
|
|
leading_digits = models.CharField(max_length=11, db_column="45extra")
|
2012-08-23 19:07:56 +00:00
|
|
|
|
2013-11-03 04:36:09 +00:00
|
|
|
|
2014-07-05 18:48:57 +00:00
|
|
|
class SpecialName(models.Model):
|
2022-02-03 19:24:19 +00:00
|
|
|
field = models.IntegerField(db_column="field")
|
2012-08-23 20:50:25 +00:00
|
|
|
# Underscores
|
2022-02-03 19:24:19 +00:00
|
|
|
field_field_0 = models.IntegerField(db_column="Field_")
|
|
|
|
field_field_1 = models.IntegerField(db_column="Field__")
|
|
|
|
field_field_2 = models.IntegerField(db_column="__field")
|
2012-08-23 20:50:25 +00:00
|
|
|
# Other chars
|
2022-02-03 19:24:19 +00:00
|
|
|
prc_x = models.IntegerField(db_column="prc(%) x")
|
|
|
|
non_ascii = models.IntegerField(db_column="tamaño")
|
2013-01-31 19:34:36 +00:00
|
|
|
|
2014-07-05 18:48:57 +00:00
|
|
|
class Meta:
|
|
|
|
db_table = "inspectdb_special.table name"
|
|
|
|
|
2013-11-03 04:36:09 +00:00
|
|
|
|
2023-05-21 21:00:25 +00:00
|
|
|
class PascalCaseName(models.Model):
|
|
|
|
class Meta:
|
|
|
|
db_table = "inspectdb_pascal.PascalCase"
|
|
|
|
|
|
|
|
|
2013-01-31 19:34:36 +00:00
|
|
|
class ColumnTypes(models.Model):
|
|
|
|
id = models.AutoField(primary_key=True)
|
2013-02-01 01:00:25 +00:00
|
|
|
big_int_field = models.BigIntegerField()
|
2013-08-11 20:19:09 +00:00
|
|
|
bool_field = models.BooleanField(default=False)
|
2017-05-06 14:56:28 +00:00
|
|
|
null_bool_field = models.BooleanField(null=True)
|
2013-02-01 01:00:25 +00:00
|
|
|
char_field = models.CharField(max_length=10)
|
2014-10-20 18:05:43 +00:00
|
|
|
null_char_field = models.CharField(max_length=10, blank=True, null=True)
|
2013-02-01 01:00:25 +00:00
|
|
|
date_field = models.DateField()
|
|
|
|
date_time_field = models.DateTimeField()
|
|
|
|
decimal_field = models.DecimalField(max_digits=6, decimal_places=1)
|
|
|
|
email_field = models.EmailField()
|
|
|
|
file_field = models.FileField(upload_to="unused")
|
|
|
|
file_path_field = models.FilePathField()
|
|
|
|
float_field = models.FloatField()
|
|
|
|
int_field = models.IntegerField()
|
2017-01-19 10:00:41 +00:00
|
|
|
gen_ip_address_field = models.GenericIPAddressField(protocol="ipv4")
|
2019-10-16 12:32:12 +00:00
|
|
|
pos_big_int_field = models.PositiveBigIntegerField()
|
2013-02-01 01:00:25 +00:00
|
|
|
pos_int_field = models.PositiveIntegerField()
|
|
|
|
pos_small_int_field = models.PositiveSmallIntegerField()
|
|
|
|
slug_field = models.SlugField()
|
|
|
|
small_int_field = models.SmallIntegerField()
|
|
|
|
text_field = models.TextField()
|
|
|
|
time_field = models.TimeField()
|
|
|
|
url_field = models.URLField()
|
2016-07-20 07:01:57 +00:00
|
|
|
uuid_field = models.UUIDField()
|
2014-07-14 20:42:05 +00:00
|
|
|
|
|
|
|
|
2019-06-09 00:56:37 +00:00
|
|
|
class JSONFieldColumnType(models.Model):
|
|
|
|
json_field = models.JSONField()
|
|
|
|
null_json_field = models.JSONField(blank=True, null=True)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
required_db_features = {
|
2022-02-03 19:24:19 +00:00
|
|
|
"can_introspect_json_field",
|
|
|
|
"supports_json_field",
|
2019-06-09 00:56:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-06-01 14:39:52 +00:00
|
|
|
test_collation = SimpleLazyObject(
|
|
|
|
lambda: connection.features.test_collations.get("non_default")
|
|
|
|
)
|
2020-07-18 11:17:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
class CharFieldDbCollation(models.Model):
|
|
|
|
char_field = models.CharField(max_length=10, db_collation=test_collation)
|
|
|
|
|
|
|
|
class Meta:
|
2022-02-03 19:24:19 +00:00
|
|
|
required_db_features = {"supports_collation_on_charfield"}
|
2020-07-18 11:17:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TextFieldDbCollation(models.Model):
|
|
|
|
text_field = models.TextField(db_collation=test_collation)
|
|
|
|
|
|
|
|
class Meta:
|
2022-02-03 19:24:19 +00:00
|
|
|
required_db_features = {"supports_collation_on_textfield"}
|
2020-07-18 11:17:39 +00:00
|
|
|
|
|
|
|
|
2022-11-10 18:31:31 +00:00
|
|
|
class CharFieldUnlimited(models.Model):
|
|
|
|
char_field = models.CharField(max_length=None)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
required_db_features = {"supports_unlimited_charfield"}
|
|
|
|
|
|
|
|
|
2014-07-14 20:42:05 +00:00
|
|
|
class UniqueTogether(models.Model):
|
|
|
|
field1 = models.IntegerField()
|
|
|
|
field2 = models.CharField(max_length=10)
|
2022-02-03 19:24:19 +00:00
|
|
|
from_field = models.IntegerField(db_column="from")
|
|
|
|
non_unique = models.IntegerField(db_column="non__unique_column")
|
|
|
|
non_unique_0 = models.IntegerField(db_column="non_unique__column")
|
2014-07-14 20:42:05 +00:00
|
|
|
|
|
|
|
class Meta:
|
2015-11-06 16:29:23 +00:00
|
|
|
unique_together = [
|
2022-02-03 19:24:19 +00:00
|
|
|
("field1", "field2"),
|
|
|
|
("from_field", "field1"),
|
|
|
|
("non_unique", "non_unique_0"),
|
2015-11-06 16:29:23 +00:00
|
|
|
]
|
2022-04-16 13:29:51 +00:00
|
|
|
|
|
|
|
|
|
|
|
class FuncUniqueConstraint(models.Model):
|
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
rank = models.IntegerField()
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
constraints = [
|
|
|
|
models.UniqueConstraint(
|
|
|
|
Lower("name"), models.F("rank"), name="index_lower_name"
|
|
|
|
)
|
|
|
|
]
|
|
|
|
required_db_features = {"supports_expression_indexes"}
|
2022-10-16 05:59:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
class DbComment(models.Model):
|
|
|
|
rank = models.IntegerField(db_comment="'Rank' column comment")
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table_comment = "Custom table comment"
|
|
|
|
required_db_features = {"supports_comments"}
|