一.字段
AutoField(Field) - int自增列,必須填入參數 primary_key=True BigAutoField(AutoField) - bigint自增列,必須填入參數 primary_key=True 注:當model中如果沒有自增列,則自動會創建一個列名為id的列 from django.db import models class UserInfo(models.Model): # 自動創建一個列名為id的且為自增的整數列 username = models.CharField(max_length=32) class Group(models.Model): # 自定義自增列 nid = models.AutoField(primary_key=True) name = models.CharField(max_length=32)
SmallIntegerField(IntegerField): - 小整數 -32768 ~ 32767
-----------實例:number=models.x() 無參數 PositiveSmallIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField) - 正小整數 0 ~ 32767
--------------實例:numebr=models.x() 無參數
IntegerField(Field) - 整數列(有符號的) -2147483648 ~ 2147483647
---------------實例:numebr=models.x() 無參數 PositiveIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField) - 正整數 0 ~ 2147483647 BigIntegerField(IntegerField): - 長整型(有符號的) -9223372036854775808 ~ 9223372036854775807 BooleanField(Field) - 布爾值類型
-----------實例:b=BooleanField() 在mysql中只能是0或1,True/False不行 NullBooleanField(Field): - 可以為空的布爾值 CharField(Field) - 字符類型 - 必須提供max_length參數, max_length表示字符長度
----------實例:name=models.CharField(max_length=32,blank=True,null=True) #平均3個字節存一個漢字,blank=True是DjangoAdmin可為空,null=True是數據庫可為空,在寫此字段時,建議兩者都寫 TextField(Field) - 文本類型 EmailField(CharField): - 字符串類型,Django Admin以及ModelForm中提供驗證機制 IPAddressField(Field) - 字符串類型,Django Admin以及ModelForm中提供驗證 IPV4 機制 GenericIPAddressField(Field) - 字符串類型,Django Admin以及ModelForm中提供驗證 Ipv4和Ipv6 - 參數: protocol,用於指定Ipv4或Ipv6, 'both',"ipv4","ipv6" unpack_ipv4, 如果指定為True,則輸入::ffff:192.0.2.1時候,可解析為192.0.2.1,開啟刺功能,需要protocol="both" URLField(CharField) - 字符串類型,Django Admin以及ModelForm中提供驗證 URL SlugField(CharField) - 字符串類型,Django Admin以及ModelForm中提供驗證支持 字母、數字、下划線、連接符(減號) CommaSeparatedIntegerField(CharField) - 字符串類型,格式必須為逗號分割的數字 UUIDField(Field) - 字符串類型,Django Admin以及ModelForm中提供對UUID格式的驗證 FilePathField(Field) - 字符串,Django Admin以及ModelForm中提供讀取文件夾下文件的功能 - 參數: path, 文件夾路徑 match=None, 正則匹配 recursive=False, 遞歸下面的文件夾 allow_files=True, 允許文件 allow_folders=False, 允許文件夾 FileField(Field) - 字符串,路徑保存在數據庫,文件上傳到指定目錄 - 參數: upload_to = "" 上傳文件的保存路徑 storage = None 存儲組件,默認django.core.files.storage.FileSystemStorage
--------實例:
class File(models.Model):
file=models.FileField(upload_to="files") 一旦有上傳的文件,將其寫入數據庫后,會自動生成files文件,並將文件放在files文件夾下
ImageField(FileField) - 字符串,路徑保存在數據庫,文件上傳到指定目錄 - 參數: upload_to = "" 上傳文件的保存路徑 storage = None 存儲組件,默認django.core.files.storage.FileSystemStorage width_field=None, 上傳圖片的高度保存的數據庫字段名(字符串) height_field=None 上傳圖片的寬度保存的數據庫字段名(字符串)
--------實例:
class IMG(models.Model):
w=models.IntegerField()
h=models.IntegerField()
img=models.ImageField(upload_to="img",width_field="w",height_field="h") 獲取上傳文件的寬高,並將寬高添加w/h字段中 ps:寬高只能獲取,不能修改
DateTimeField(DateField) - 日期+時間格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]
------------實例:
date=models.DateTimeField(auto_now=True) 最新的修改時間,對象調用save()方法時自動更新時間(nid=models.表名.objects.get(id=1) nid.字段="" nid.save())
date1=models.DateTimeField(auto_now_add=True) 最開始的時間
在django+mysql數據庫中,保存到數據庫中的datetime(auto_now=True)只有執行了對象的save方法才會更新時間,最新修改時間會比本地當前 時間慢8個小時左右 解決方法:settings.py TIME_ZONE = 'Asia/Shanghai' USE_TZ = False time=datetime(auto_now_add=True)命令行會提示輸入當前時間,輸入:datetime.datetime.now()
DateField(DateTimeCheckMixin, Field) - 日期格式 YYYY-MM-DD TimeField(DateTimeCheckMixin, Field) - 時間格式 HH:MM[:ss[.uuuuuu]] DurationField(Field) - 長整數,時間間隔,數據庫中按照bigint存儲,ORM中獲取的值為datetime.timedelta類型 FloatField(Field) - 浮點型 DecimalField(Field) - 10進制小數 - 參數: max_digits,小數總長度 decimal_places,小數位長度 BinaryField(Field) - 二進制類型
---只能在djangoadmin中添加數據
source_choices=((0,"轉介紹"),(1,"qq"),(2,"官網"))
source=models.SmallIntegerField(choices=source_choices)
二.參數
unique=True 唯一(當前字段不能有相同的)
blank=True DjangoAdmin中可為空
null=True 數據庫中可為空,通常建議兩者合並起來用
verbose_name="xx" 當前字段的在Admin中的別名
default=False 默認值為False
二.ImgField實例
---------views.py def uploadimg(req): if req.method=="POST": news=models.IMG.objects.create( img=req.FILES.get("img"), #將得到的文件放在img字段下(其實是文件路徑) name=req.FILES.get("img").name ) news.save() return render(req,"img_tem/uploading.html")
def showimg(req): imgs=models.IMG.objects.all() content={ "imgs":imgs, } for i in imgs: print(i.img.url) return render(req,"img_tem/showing.html",content) def file_upload(req): if req.method=="POST": models.File.objects.create( file=req.FILES.get("file") ) return render(req,"img_tem/uploading.html")
--------urls.py
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.contrib import staticfiles
urlpatterns = [ path('upload',views.uploadimg), path('show',views.showimg), path('file_upload',views.file_upload), ] urlpatterns += staticfiles_urlpatterns()
---------settings.py STATIC_URL = '/static/' #別名
STATICFILES_DIRS = ( os.path.join(BASE_DIR, "static"), # 實際名 ,即實際文件夾的名字 )
---------models.py class IMG(models.Model): img=models.ImageField(upload_to="static/img") //一旦有上傳文件,就在static文件夾下創建img文件 name=models.CharField(max_length=20) class File(models.Model): file=models.FileField(upload_to="file") //有上傳文件,會自動新建file文件
-------templates文件下新建img_tem文件,文件中添加兩個html -------uploading.html <form action="" method="post" enctype="multipart/form-data"> {% csrf_token %} <input type="file" name="img"> <input type="file" name="file"> <button type="submit">上傳</button> </form> --------showing.html <body> {% for img in imgs %} <img src="/{{ img.img.url}}" alt=""> //獲取文件路徑,第二個img是IMG表中的img字段 {% endfor %} </body>