Django基础-001
一、开发模式
MVC模式:
model:数据库
view:前端展示
controller:逻辑控制
MTV模式
model:数据库
view:逻辑控制
template:前端展示
二、Django介绍
flask,FastApi是轻量级服务端开发框架
Django是重量级服务端开发框架
ORM:封装了数据库操作
form:校验请求数据
安装Django:
pip install django==2.1 #指定版本安装,默认是安装最新版本
注意:最新版本的Django对mysql版本也有要求
三、Django命令
1.创建项目命令:django-admin startproject ssz_django
2.启动项目命令:
python manage.py runserver 默认端口启动8000
python manage.py runserver 0.0.0.0:8002 指定端口启动,别人也可以访问
python manage.py runserver 127.0.0.1:8002 指定端口启动,只能自己访问
3.创建子模块:python manage.py startapp user
4.创建表结构:
python manage.py makemigrations #生成建表/更新表的py文件
python manage.py migrate #根据上面命令生成的py文件,来建表/更新表
5.查询命令
python manage.py --help
四、pycharm操作
4.1 pycharm创建项目
File--New Project--Django
4.2 pycharm创建子模块
Tools--Run manage.py Task 进入命令行
startapp user #创建user子模块
五、Django项目介绍
5.1 项目整体结构
5.2 urls.py
该文件是用来配置url的
1 from django.contrib import admin 2 from django.urls import path 3 from user import views #引入模块 4 5 urlpatterns = [ 6 path('admin/', admin.site.urls), 7 path('index/', views.user_info), 8 path('welcome/',views.welcome), 9 path('',views.index),#配置url 10 ]
5.3 settings.py
该文件是配置文件,数据库等配置
1 import os 2 3 # Build paths inside the project like this: os.path.join(BASE_DIR, ...) 4 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) 5 6 7 # Quick-start development settings - unsuitable for production 8 # See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/ 9 10 # SECURITY WARNING: keep the secret key used in production secret! 11 SECRET_KEY = '6ui+975ck&h4o8f9ga!lnz%j7u&se&-%69&-(h(4!-q4n80y9c' 12 13 # SECURITY WARNING: don't run with debug turned on in production! 14 DEBUG = True 15 16 ALLOWED_HOSTS = [] 17 18 19 # Application definition 20 21 INSTALLED_APPS = [ #加增加的应用 22 'django.contrib.admin', 23 'django.contrib.auth', 24 'django.contrib.contenttypes', 25 'django.contrib.sessions', 26 'django.contrib.messages', 27 'django.contrib.staticfiles', 28 'user', 29 'test_tools', 30 'case' 31 ] 32 33 MIDDLEWARE = [ 34 'django.middleware.security.SecurityMiddleware', 35 'django.contrib.sessions.middleware.SessionMiddleware', 36 'django.middleware.common.CommonMiddleware', 37 'django.middleware.csrf.CsrfViewMiddleware', 38 'django.contrib.auth.middleware.AuthenticationMiddleware', 39 'django.contrib.messages.middleware.MessageMiddleware', 40 'django.middleware.clickjacking.XFrameOptionsMiddleware', 41 ] 42 43 ROOT_URLCONF = 'sky.urls' 44 45 TEMPLATES = [ 46 { 47 'BACKEND': 'django.template.backends.django.DjangoTemplates', 48 'DIRS': [os.path.join(BASE_DIR,'templates')],#指的是Django寻找html的目录 49 'APP_DIRS': True, 50 'OPTIONS': { 51 'context_processors': [ 52 'django.template.context_processors.debug', 53 'django.template.context_processors.request', 54 'django.contrib.auth.context_processors.auth', 55 'django.contrib.messages.context_processors.messages', 56 ], 57 }, 58 }, 59 ] 60 61 WSGI_APPLICATION = 'sky.wsgi.application' 62 63 64 # Database 65 # https://docs.djangoproject.com/en/2.1/ref/settings/#databases 66 67 DATABASES = { 68 'default': { 69 'ENGINE': 'django.db.backends.sqlite3', 70 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 71 } 72 } 73 74 75 # Password validation 76 # https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators 77 78 AUTH_PASSWORD_VALIDATORS = [ 79 { 80 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', 81 }, 82 { 83 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', 84 }, 85 { 86 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', 87 }, 88 { 89 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', 90 }, 91 ] 92 93 94 # Internationalization 95 # https://docs.djangoproject.com/en/2.1/topics/i18n/ 96 97 #LANGUAGE_CODE = 'en-us' #英文 98 LANGUAGE_CODE = 'zh-Hans'#中文 99 100 TIME_ZONE = 'Asia/Shanghai'#时区 101 102 USE_I18N = True 103 104 USE_L10N = True 105 106 USE_TZ = False#True:往数据库里插数据,用的标准时区的时间 107 108 109 # Static files (CSS, JavaScript, Images) 110 # https://docs.djangoproject.com/en/2.1/howto/static-files/ 111 112 STATIC_URL = '/static/' 113 114 STATICFILES_DIRS = ( 115 os.path.join(BASE_DIR,'static'), 116 ) 117 118 MEDIA_ROOT = os.path.join(BASE_DIR,'images')#图片的总目录 119 MEDIA_URL = '/images/'
5.4 wsgj.py
该文件是用来部署用的
5.5 manage.py
项目管理文件
5.6 models.py
操作数据库文件
建单表代码
1 from django.db import models 2 3 # Create your models here. 4 class Category(models.Model): 5 name = models.CharField(verbose_name='分类名称',max_length=20,unique=True) 6 create_time = models.DateTimeField(verbose_name='创建时间',auto_now_add=True) 7 update_time = models.DateTimeField(verbose_name='修改时间',auto_now=True) 8 class Meta: 9 db_table = 'category' #指定表名 10 verbose_name = '分类' 11 verbose_name_plural = verbose_name 12 ordering = ['-create_time','name'] #排序,默认是升序,-是降序
建有外键的表的代码
1 class Article(models.Model): 2 title = models.CharField(verbose_name='标题',max_length=50) 3 content = models.TextField(verbose_name='文章内容') 4 category = models.ForeignKey(Category,on_delete=models.DO_NOTHING,db_constraint=False,verbose_name='分类') 5 #建外键,on_delete=models.DO_NOTHING:当分类被删除时,文章不被影响 6 #db_constraint = False:不会在表中建立真实的外键关系 7 8 img = models.ImageField(upload_to='article',verbose_name='文章图片',blank=True)#图片存放的文件夹 9 create_time = models.DateTimeField(verbose_name='创建时间', auto_now_add=True) 10 update_time = models.DateTimeField(verbose_name='修改时间', auto_now=True) 11 class Meta: 12 db_table = 'article' #指定表名 13 verbose_name = '文章' 14 verbose_name_plural = verbose_name 15 ordering = ['-create_time'] #排序,默认是升序,-是降序
代码写好后,分别执行以下命令,就可以生成表结构
python manage.py makemigrations
python manage.py migrate
Django 内嵌了sqllite,默认就是将表创建在sqllite中
如果想要连接mysql等其他数据库,需要自己在settings.py文件中配置
关联删除模式:
#外键删除操作模式 #models.DO_NOTHING:不受任何影响 #models.CASCADE:关联的数据也会被删除,分类被删除,引用分类的文章也会被删除 #models.SET:传入一个方法名,用方法逻辑处理 #models.SET_DEFAULT:删除了,设置为默认值,要该字段有默认值 #models.SET_NULL:删除了,直接设置为空,要该字段可为空 #models.PROTECT#受保护,不能删除,只要这个分类下有文章,就不能删除这个分类
5.7 views.py
是用来做逻辑处理的文件
1 from django.http import HttpResponse 2 from django.shortcuts import render 3 from . import models 4 5 # Create your views here. 6 7 def user_info(request): 8 s = '你好' 9 return HttpResponse(s)#返回的是字符串 10 11 12 def welcome(request): 13 username = '谢谢啦dddd' 14 # f = open('G:\\pythonWorkspace\\day018\\sky\\templates\\welcome.html',encoding='utf-8') 15 # content = f.read() 16 # new_content = content.replace('{{ uname }}',username) 17 # return HttpResponse(new_content) 18 # render 就等于上面的一系列操作 19 return render(request,'welcome.html',{'uname':username}) 20 21 22 def index(request): 23 categories = models.Category.objects.all() 24 articles = models.Article.objects.all() 25 return render(request,'index.html',{'categories':categories,'articles':articles})
5.8 ORM操作数据库
5.8.1 增加
1 #第一种方式:增加 2 category = models.Category(name='mysql') 3 category.save() 4 5 #第二种方式:增加 6 models.Category.objects.create(name='心情日记')
5.8.2 修改
1 #修改 2 c1 = models.Category.objects.get(id=1) 3 c1.name = 'Java' 4 c1.save()#单个数据修改 5 6 #多个数据修改 7 q = models.Category.objects.filter(name='python') 8 q.update(name='Python1')
5.8.3 查询
1 #查询 2 #只能返回一条数据,如果返回多条数据会报错 3 #如果指定的条件查询不到数据,也会报错 4 c1 = models.Category.objects.get(name='linux',id=2) 5 6 #可以返回多条数据,返回结果为list,如果查询不到结果,则返回空 7 query_set = models.Category.objects.filter(name='python',id=8) 8 print(query_set.first().name) 9 print(query_set[1]) 10 print(query_set) 11 12 #查询所有的数据 13 categories = models.Category.objects.all()
5.8.4 删除
1 #删除 2 #单条数据删除 3 c1 = models.Category.objects.get(id=1) 4 c1.delete() 5 6 #多条数据删除 7 q = models.Category.objects.filter(name='Python1') 8 q.delete()
5.9 test.py
测试代码
注意:需要手动加入Django配置,才可以测试
运行Django项目时,不需要手动设置,因为在manager.py文件中配置了
1 import os,django 2 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'sky.settings')#设置数据库的路径 3 django.setup()
1 from django.test import TestCase 2 import os,django 3 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'sky.settings')#设置数据库的路径 4 django.setup() 5 6 # Create your tests here. 7 from user import models 8 9 #增加 10 category = models.Category(name='mysql') 11 category.save() 12 13 models.Category.objects.create(name='心情日记') 14 #删除 15 #单条数据删除 16 # c1 = models.Category.objects.get(id=1) 17 # c1.delete() 18 19 #多条数据删除 20 # q = models.Category.objects.filter(name='Python1') 21 # q.delete() 22 23 #修改 24 # c1 = models.Category.objects.get(id=1) 25 # c1.name = 'Java' 26 # c1.save()#单个数据修改 27 28 #多个数据修改 29 # q = models.Category.objects.filter(name='python') 30 # q.update(name='Python1') 31 32 33 #查询 34 #只能返回一条数据,如果返回多条数据会报错 35 #如果指定的条件查询不到数据,也会报错 36 c1 = models.Category.objects.get(name='linux',id=2) 37 38 #可以返回多条数据,返回结果为list,如果查询不到结果,则返回空 39 query_set = models.Category.objects.filter(name='python',id=8) 40 print(query_set.first().name) 41 print(query_set[1]) 42 print(query_set) 43 44 #查询所有的数据 45 categories = models.Category.objects.all() 46 47 # c = models.Category.objects.get(id=2) 48 # models.Article.objects.create(title='test00001',content='fsdfslkjfslkjflsdkjflsdjflsdjflskjfdslfjsd',category=c) 49 # models.Article.objects.create(title='Django项目配置',content='Django项目配置Django项目配置Django项目配置Django项目配置Django项目配置',category_id=3) 50 51 models.Article.objects.create(title='python面向对象1',content='python面向对象1python面向对象1python面向对象1',category_id=3) 52 models.Article.objects.create(title='python面向对象2',content='python面向对象2python面向对象2python面向对象2',category_id=3) 53 article = models.Article.objects.get(id='1') 54 print(article.title) 55 print(article.category.name)