python model的用法是:1、model實現增,程式碼為【book=Book(title="hello go")】;2、model實作刪,程式碼為【book=Book.objects.get (id=1),book.delete()】。
【相關學習推薦:#python教學##】
python model的用法是:
#1.首先是資料庫設定
一般新建的django專案都是配置為sqlite為資料庫通常專案中都會使用MySQL所以先修改設定在project的settings.py裡修改
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'USER':'root', 'PASSWORD':'', 'NAME':'djangouse', 'HOST':'localhost', } }USER填MySQL的使用者名稱PASSWORD填入MySQL的密碼NAME填填所使用的資料庫的名字,這個要自己到MySQL裡創建注意:使用model前記得把MySQL打開
#2.在新版的django中命令列有了很大的變化
關於model的主要有以下幾句命令python manage.py check 檢查model是否有拼寫錯誤python manage.py makemigrations 將model的改變生成一個遷移文件python manage.py migrate 執行遷移通常在建立好app和資料庫之後先執行python manage.py migrate會產生一些管理的表
3.之後是新建model
首先要導入models套件在app的models.py裡加入from django.db import models
class Book(models.Model): title=models.CharField(max_length=100) def __unicode__(self): return self.title這個Book的model有一個title字段最大長度為100unicode這個方法是回傳的是查詢到這個Object時顯示的內容,預設顯示為Object然後就是依序執行
python manage.py check 检查model是否有拼写错误 python manage.py makemigrations 将model的改变生成一个迁移文件 python manage.py migrate 执行迁移接著查詢所使用的資料庫會發現多了一個名字含有book的表
4.接下來是model的增刪查改
##增
##增
book=Book(title="hello django") book.save()
刪除
book=Book.objects.get(id=1) book.delete()
取得id為1的物件後執行delete方法
查
book=Book.objects.all()
查詢全部Book對象,傳回一個集合
book=Book.objects.get(id=1)
取得id為1的Book物件
book=Book.objects.filter(title__icontains="hello")
取得title欄位裡含有hello的Book物件集合
改book=Book.objects.get(id=1)
book.title="django"
book.save()
manager是對model一些常用方法的封裝
#有獲得數值的,也有獲得物件集合的
看看得到數值的manager怎麼創建
在app裡的model.py裡新建一個繼承自models.Manager的類別
class BookManager(models.Manager): def get_book_count(self,keyword): return self.filter(title__icontains=keyword).count()
然後把manager加進model
class Book(models.Model): title=models.CharField(max_length=100) myobjects=BookManager()
使用的時候是
count=Book.myobjects.get_book_count("hello")
這樣就回傳了名字含有book物件的數量
如果想得到一個有特殊條件物件集合呢?
新建一個manger
class PythonManager(models.Manager): def get_query_set(self): return super(PythonManager,self).get_query_set().filter(title__icontaions='hello')
把manager加進model
class Book(models.Model): title=models.CharField(max_length=100) myobjects=BookManager() pyhton_objects=PythonManager()
用的時候是
queryset=Book.pyhton_objects.get_query_set()
這樣就回傳了名字含有hello的Book物件集合
6.接下來是用後台頁面管理model###首先要在終端機輸入###python manage.py createsuperuser
以上是python model怎麼用的詳細內容。更多資訊請關注PHP中文網其他相關文章!