一、设置可选字段sql
为了设置某一个字段是可选的,不如说email,仅仅需要改动其相关的模型,也就是在model.py中改动模型,将email=models.EmailField(blank=True),也就是加入blank=True。shell
这句代码告诉Django,赞成email字段的输入为空。Django中字段的默认blank=false,便是不一样意输入为空。数据库
note:django在生成sql语句的时候,会默认的在每一个字段的后面加入一个NOT NULL的约束。防止产生空字符串和NULL混淆的问题。但是同一时候却引入了新的问题。对于日期类型和数字类型的数据,直接设置blank=true的时候。很是多数据库都会抛出异常。这是因为插入空的字符串和日期类型或者数字类型是不相符的。工具
假设真的想为日期或者数字类型的字段插入空的字符串的时候,需要在blank=True,null=True。加入了null=True,至关于更改的数据库的结构,需要改动数据库中的相关的字段。post
可以执行manage.py dbshell命令来改动数据库:spa
ALTER TABLE table_name ALTER COLUMN colunm_name DROP NOT NULL;
二、本身定义字段标签字符串
加入verbose_nameit
note:可以在固定的位置隐式的引用这个字段,直接将它放在第一个參数就可直接引用。io
但是却对于ManyToMany和ForeignKey的字段并不有用,在这种字段中必须显示的引用字段。table
三、本身定义列表
加入ModelAdmin类,这个类是本身定义管理工具的关键。可以在admin.py中改动。參考例如如下:
**class AuthorAdmin(admin.ModelAdmin):** **list_display = ('first_name', 'last_name', 'email')**
class AuthorAdmin(admin.ModelAdmin): list_display = ('first_name', 'last_name', 'email') **search_fields = ('first_name', 'last_name')**这样就可以在界面的上面加入一个模糊搜索框。
**class BookAdmin(admin.ModelAdmin):** **list_display = ('title', 'publisher', 'publication_date')** **list_filter = ('publication_date',)**
**admin.site.register(Book, BookAdmin)**