【发布时间】:2018-12-06 23:19:40
【问题描述】:
我的 sqlite3 数据库中有以下表格:
PRAGMA table_info(auth_user);
0|id|integer|1||1
1|password|varchar(128)|1||0
2|last_login|datetime|0||0
3|is_superuser|bool|1||0
4|username|varchar(150)|1||0
5|first_name|varchar(30)|1||0
6|email|varchar(254)|1||0
7|is_staff|bool|1||0
8|is_active|bool|1||0
9|date_joined|datetime|1||0
10|last_name|varchar(150)|1||0
PRAGMA table_info(accounts_member);
0|id|integer|1||1
1|team_id|integer|1||0
2|user_id|integer|1||0
3|department_id|integer|1||0
最后:
PRAGMA table_info(accounts_department);
0|id|integer|1||1
1|name|varchar(20)|1||0
2|description|varchar(255)|1||0
以上三个表以下列方式相互关联:
auth_user 是链接表的主表。
accounts_member 使用外键 user_id 引用 auth_user,还使用外键 department_id 引用 accounts_department。
select * from auth_user
inner join accounts_member on accounts_member.user_id = auth_user.id
inner join account_department on account_department.department_id = accounts_member.id
我有不同的教程,但我得到的大多数教程都需要使用 where 函数条件。
以下是我的模型: 对于accounts_department
class Department(models.Model):
class Meta:
get_latest_by = "name"
name = models.CharField(max_length=20)
description = models.CharField(max_length=255)
def __str__(self):
return self.name
def get_absolute_url(self):
return
对于accounts_member:
class Member(models.Model):
team = models.ForeignKey(Profile, models.CASCADE)
user = models.ForeignKey(User, models.CASCADE, related_name="memberships")
department = models.OneToOneField(Department, models.CASCADE, blank=True, null=True)
并且表 auth_user 使用 django 的内置模型。
我在 views.py 中尝试了以下内容:
profile = request.profile
department = Department.objects.all()
members = Member.objects.filter(is_active=1).select_related("user","department")
data = {
"page": "profile",
"profile": profile,
'departments': department,
"members_list": members,
"show_api_keys": False,
"api_status": "default",
"team_status": "default"
}
但它只返回表 accounts_member 的值,我如何获取所有值?
【问题讨论】:
-
你能分享你的模型类吗?
-
@ruddra,我已经更新了问题以包括我的模型和视图
标签: django python-3.x django-models django-views