django提供完善的模型(model)层主要用来创建和存取数据,不需要我们直接对数据库操作。
django模型基础知识:
每个模型是一个python类,继承django.db.models.model类。
该模型的每个属性表示一个数据库表字段。
所有者一切,django都自带数据库访问的API。
在应用层打开models.py,完成表的创建。
from django.db import models
# Create your models here.
# 发布会表
class Event(models.Model):
name = models.CharField(max_length=100)
limit = models.IntegerField()
status = models.BooleanField()
address = models.CharField(max_length=200)
start_time = models.DateTimeField('events time')
create_time = models.DateTimeField(auto_now=True)
def __str__(self):
return self.name
# 嘉宾表
class Guest(models.Model):
event = models.ForeignKey(Event, on_delete=models.CASCADE)
realname = models.CharField(max_length=64)
phone = models.CharField(max_length=16)
email = models.BooleanField()
sign = models.BooleanField()
create_time = models.DateTimeField(auto_now=True)
class Meta:
unique_together = ("event", "phone")
def __str__(self):
return self.realname
其中表格的外键有一个参数必须设置,特别注意一下,因为on_delete参数是django后面框架加入的强制设置,之前的版本没有。
- CASCADE:删除表的数据一并删除关联表的所有关联数据;
- PROTECT:删除表的数据时,采取保护机制,抛出错误:即如果有关联数据,就不能删除;
- SET_NULL:只有当null=True才将关联的内容置空;
- SET_DEFAULT:设置为默认值;
- SET( ):括号里可以是函数,设置为自己定义的东西;
- DO_NOTHING:字面的意思,啥也不干,你删除你的干我毛线关系
这个必须引起重视。
然后执行python manage.py makemigrations sign进行数据库迁移。
追加补充:
捣鼓了好久,发现在后台管理平台上,有表格,但点击添加或者更改,就报错了
python manage.py makemigrations sign
python manage.py migrate
需要执行这两个指令,可以简单理解为编译和提交
print_r('点个赞吧');
var_dump('点个赞吧');
NSLog(@"点个赞吧!")
System.out.println("点个赞吧!");
console.log("点个赞吧!");
print("点个赞吧!");
printf("点个赞吧!\n");
cout << "点个赞吧!" << endl;
Console.WriteLine("点个赞吧!");
fmt.Println("点个赞吧!")
Response.Write("点个赞吧");
alert(’点个赞吧’)