我对Web应用程序和数据库的新东西都很陌生,所以这可能是一个愚蠢的问题.我想创建一个模型("CategoryModel"),其中的字段指向模型的另一个实例(其父项)的主要ID.
class CategoryModel(models.Model):
parentId = models.ForeignKey(CategoryModel)
Run Code Online (Sandbox Code Playgroud)
我该怎么做呢?谢谢!
假设我们上课了Employee.我想要一个引用同一个类的不同实例的字段.
怎么写这个?以下代码怎么样?
ref_employee= models.ForeignKey('self',null=True,blank=True)
Run Code Online (Sandbox Code Playgroud) 我的应用程序中有以下内容:
class University(models.Model):
...
sister_university = models.OneToOneField('self', related_name =
'university_sister_university',
blank=True, null=True,
on_delete=models.SET_NULL)
Run Code Online (Sandbox Code Playgroud)
我只希望大学在这种关系的两个方向上与另一所大学有关.
例如,在数据库中,如果我选择大学A作为大学B的姐妹大学,我只希望被允许选择大学B作为大学A下的姐妹大学.但是,实际上,第二种关系没有得到强制执行.
例如:现在,在Django Admin网站下,如果我首先选择大学A作为大学B的姐妹大学,我仍然可以选择任何其他大学作为大学A姐妹大学的对象.我不仅限于选择大学B.
是否可以在数据库级别强制执行该唯一性?有没有更好的方法来完成我想要做的事情?
我正在尝试创建模型页面,页面也应该能够有"子页面".
我的下面的模型代码一直在我的Mac(python 2.6.1)和Ubuntu 10.04(python 2.6.5)上崩溃:
from django.db import models
from django.contrib import admin
class Page(models.Model):
slug = models.SlugField(blank=True)
title = models.CharField(max_length=100)
content = models.TextField(blank=True)
children = models.ManyToManyField("self", blank=True)
published = models.BooleanField(default=True)
created = models.DateTimeField(blank=True, auto_now_add=True)
def html(self):
html = "<li>"
html += self.title
children = self.children.all()
if len(children) > 0:
for page in children:
html += page.html()
html += "</li>"
return html
def __unicode__(self):
return self.title
class PageAdmin(admin.ModelAdmin):
prepopulated_fields = {'slug': ('title',)}
admin.site.register(Page, PageAdmin)
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?或者这种HTML渲染是否属于视图?
谢谢.