Django中的Model(字段)

Model

Django中的model是用来操作数据库的,Model是一个ORM框架,我们只需要关心model的操作,而不需要关心到底是哪一种数据库。

一、基本知识:

数据库引擎:

Django中自带的数据库为sqlite,如果需要修改数据库引擎,可以再settings.py中修改:

 DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}

使用方法:

我们只需要在models.py文件中写入代码即可:

Django中的Model(字段)

表结构对照图:

ORM框架中,类class表示数据库的表
根据类创建的对象,代表数据库表中的一行数据。
对象.id 对象.value 代表行里面的数据

Django中的Model(字段)

二、model里的字段

1、models.AutoField  自增列 = int(11)
  如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True。
2、models.CharField  字符串字段
  必须 max_length 参数
3、models.BooleanField  布尔类型=tinyint(1)
  不能为空,Blank=True
4、models.ComaSeparatedIntegerField  用逗号分割的数字=varchar
  继承CharField,所以必须 max_lenght 参数
5、models.DateField  日期类型 date
  对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。
6、models.DateTimeField  日期类型 datetime
  同DateField的参数
7、models.Decimal  十进制小数类型 = decimal
  必须指定整数位max_digits和小数位decimal_places
8、models.EmailField  字符串类型(正则表达式邮箱) =varchar
  对字符串进行正则表达式
9、models.FloatField  浮点类型 = double
10、models.IntegerField  整形
11、models.BigIntegerField  长整形
  integer_field_ranges = {
    'SmallIntegerField': (-32768, 32767),
    'IntegerField': (-2147483648, 2147483647),
    'BigIntegerField': (-9223372036854775808, 9223372036854775807),
    'PositiveSmallIntegerField': (0, 32767),
    'PositiveIntegerField': (0, 2147483647),
  }
12、models.IPAddressField  字符串类型(ip4正则表达式)
13、models.GenericIPAddressField  字符串类型(ip4和ip6是可选的)
  参数protocol可以是:both、ipv4、ipv6
  验证时,会根据设置报错
14、models.NullBooleanField  允许为空的布尔类型
15、models.PositiveIntegerFiel  正Integer
16、models.PositiveSmallIntegerField  正smallInteger
17、models.SlugField  减号、下划线、字母、数字
18、models.SmallIntegerField  数字
  数据库中的字段有:tinyint、smallint、int、bigint
19、models.TextField  字符串=longtext
20、models.TimeField  时间 HH:MM[:ss[.uuuuuu]]
21、models.URLField  字符串,地址正则表达式
22、models.BinaryField  二进制
23、models.ImageField 图片 在数据库中保存的是文件的路径
24、models.FilePathField 文件

三、字段中的参数

1、null=True
  数据库中字段是否可以为空
2、blank=True
  django的 Admin 中添加数据时是否可允许空值
3、primary_key = False
  主键,对AutoField设置主键后,就会代替原来的自增 id 列
4、auto_now 和 auto_now_add
  auto_now 自动创建---无论添加或修改,都是当前操作的时间
  auto_now_add 自动创建---永远是创建时的时间
5、choices
GENDER_CHOICE = (
(u'M', u'Male'),
(u'F', u'Female'),
)
gender = models.CharField(max_length=2,choices = GENDER_CHOICE)
6、max_length
7、default  默认值
8、verbose_name  Admin中字段的显示名称
9、name|db_column  数据库中的字段名称
10、unique=True  不允许重复
11、db_index = True  数据库索引
12、editable=True  在Admin里是否可编辑
13、error_messages=None  错误提示
14、auto_created=False  自动创建
15、help_text  在Admin中提示帮助信息
16、validators=[]
17、upload-to 上传路径

四、上传文件

根据上传文件的契机,来写一个简单的上传文件的例子

html文件

前端代码
 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body> <form action="/upload/" method="POST" enctype="multipart/form-data"> <p><input type="file" name="f1"></p>
<p><input type="file" name="f2"></p>
<p><input type="text" name="hostname"></p>
<input type="submit" value="上传"> </form> </body>
</html>


views.py

 def upload(request):

     if request.method == "POST":
inp_file = request.FILES # 上传的文件会在request.FILES里
file_obj1 = inp_file.get('f1') # 根据前端设置的name属性值获取相对应的文件 print inp_file
print file_obj1.name # 获取文件名
print file_obj1.size
f = open(file_obj1.name, 'wb') # 以获取的文件名 按‘wb’的方式打开一个文件
for line in file_obj1.chunks(): # chunks方法读取文件,默认每次读取64kb
f.write(line)
f.close()
return render(request, 'home/upload.html')

 

上一篇:【前端基础系列】理解bind方法使用与实现


下一篇:js梳理