django(django項目創建,數據庫遷移)


Django項目的創建與介紹

安裝:pip3 install django==1.11
查看版本號:django-admin --version
新建項目:
1.切到目標目錄
2.django-admin startproject 項目名

proj_name:項目目錄,包含項目最基本的一些配置
	-- __init__.py:模塊的配置文件
	-- settings.py:配置總文件
	-- urls.py:url配置文件,django項目中的所有頁面都需要對其配置url地址
	-- wsgi.py:(web server gateway interface),服務器網關接口,python應用與web服務器直接通信的接口
templates:模板文件夾,存放html文件的(頁面),支持使用Django模板語言(DTL),也可以使用第三方(jinja2)
manage.py:項目管理器,與項目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py

應用的創建與介紹

'''
1.Django是面向應用開發,在應用中完成具體的業務邏輯
2.什么是應用app: 就好比項目中的一個功能模塊,一個項目可以擁有多個功能模塊,但至少得有一個,Django稱之為app
3.如何創建app(在項目目錄下):python3 manage.py startapp app01

migrations:數據遷移(移植)模塊,內容都是由Django自動生成
	-- __init__.py
__init__.py
admin.py:應用的后台管理系統配置
apps.py:django 1.9后,本應用的相關配置
models.py:數據模型模塊,使用ORM框架,類似於MVC模式下的Model層
tests.py:自動化測試模塊,可以寫自動化測試腳本
views.py:執行相應的邏輯代碼模塊
'''

啟動項目

python3 manage.py runserver 127.0.0.1:8888

pycharm創建啟動項目

1.創建django
2.選擇項目目錄(從項目目錄開始,目錄文件夾及子文件夾不要出現中文,保證電腦名字不能為中文)
3.配置默認模板語言,模板路徑,app名
4.啟動

生命周期

1.瀏覽器發送請求
2.wsgi服務器接收到請求,將請求解析交給django
3.Django中間件過濾請求信息,交給路由
4.路由完成業務邏輯的分發,到指定app下views中指定的視圖函數
5.視圖函數完成具體的業務邏輯,返回響應結果
6.將處理結果通過服務器返回給瀏覽器

三件套

from django.shortcuts import HttpResponse,render,redirect
def foo(request):
    return HttpResponse("msg")
def foo1(request):
    return render(request,"template_page.html",{k:v})
def foo2(request):
    return redirect('/index/')

靜態文件

動態文件:結果動態變化,如顯示登陸結果的html文件
靜態文件:不變化的文件,如css文件,圖片
因為在處理靜態文件時,瀏覽器可以將靜態文件存入緩存,不用每次請求都重新下載
,故靜態文件有單獨的處理方式
1.在項目根目錄下創建static文件夾
2.在settings.py中設置
STATIC_URL = '/static/'#靜態文件請求跟路由
STATICFILES_DIRS = [os.path.join(BASE_DIR,'static')]
3.靜態文件就放在static根目錄或子目錄下
4.獲取靜態文件:/static/目標文件(可以包含static子文件夾路徑)

請求及數據

請求路徑:
 1."/":默認向當前路徑發送請求
 2./index/:向index路徑發送請求
    
 數據:
 請求方式(get|post):request.method
 GET請求方式方式獲取數據:
    request.GET.get("key")
 POST請求方式獲取數據:
    request.POST.get("key")
    

配置Mysql完成數據遷移


1.在settings.py中將數據庫更換為mysql
HOST,USER,PASSWORD必須大寫,PASSWORD寫成PASSWD會報錯
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'dj04',
        'HOST':'127.0.0.1',
        'USER':'root',
        'PASSWORD':'123'
    }
}

2.在項目或應用的init文件中修改連接數據庫的模塊為pymysql
import pymysql
pymysql.install_as_MySQLdb()
#py2中使用mysqldb連接數據庫,py3使用pymysql,故需要用pymysql替換掉Mysqldb

3.在models建好類(對應到數據庫的表)
from django.db.models import *
# Create your models here.
class User(Model):
    id = AutoField(primary_key=True)
    user = CharField(max_length=20)
    pwd = CharField(max_length=20)
    
3.在項目目錄下,執行(生成遷移數據,沒有映射到數據庫):
①在cmd中操作
1.切到項目根目錄
2.python3 manage.py makemigrations
②在pycharm terminal中執行
python3 manage.py makemigrations
③在pycharm tools工具中的
run manage.py Task 執行 makemigrations
#執行完makemigrations會在項目的migrations文件夾中生成_initial.py

4.映射到數據庫(在數據庫建表)
python3 manage.py migrate
#在數據庫創建的表名為 項目名_類名

單表ORM記錄的增刪改查

增
①User.objects.create(user="abc",pwd="123")
②user = User(user = "abc",pwd ="123")
user.save()

刪
User.objects.filter(id=1).delete()

改
User.objects.filter(pwd="123").update(pwd="000")

查
User.objects.filter(pwd ="000").all()
User.objects.filter(pwd ="000").first()

#在django的創建的類,無需初始化,繼承了字典父類,傳參必須使用key,value形式


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM