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)
Django基础-001的更多相关文章
- Python之路-(js正则表达式、前端页面的模板套用、Django基础)
js正则表达式 前端页面的模板套用 Django基础 js正则表达式: 1.定义正则表达式 /.../ 用于定义正则表达式 /.../g 表示全局匹配 /.../i 表示不区分大小写 /.../m ...
- Django 基础教程
Django 基础教程 这是第一篇 Django 简介 » Django 是由 Python 开发的一个免费的开源网站框架,可以用于快速搭建高性能,优雅的网站! 你一定可以学会,Django 很简单 ...
- python的django基础篇
一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...
- Python学习(二十六)—— Django基础一
转载自:http://www.cnblogs.com/liwenzhou/p/8258992.html 一.Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的 ...
- Django基础(一)
Django基础(一) 知识预览 Django基本命令 二 路由配置系统(URLconf) 三 编写视图 四 Template 五 数据库与ORM admin的配置 一 什么是web框架? 框架,即f ...
- python3之Django基础篇
一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...
- DJango 基础 (1)
django基础 知识点: 基本认知 工具准备 新建项目 目录及文件说明 开发服务器 创建视图函数 新建应用(app) 1.基本认知 Django是用Python开发的一个免费开源的Web框架,可以用 ...
- Django基础和基本使用
Django基础 Django是Python下的一款著名的Web框架 框架 任何语言进入到高级部分时,会有认证.session.http.连接数据库等等功能操作,没有框架时需要自己实现 框架 是整个或 ...
- {Django基础十之Form和ModelForm组件}一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 ModelForm
Django基础十之Form和ModelForm组件 本节目录 一 Form介绍 二 Form常用字段和插件 三 From所有内置字段 四 字段校验 五 Hook钩子方法 六 进阶补充 七 Model ...
随机推荐
- Go语言基础包之net/http
Go语言基础包之net/http Go语言内置的net/http包十分的优秀,提供了HTTP客户端和服务端的实现. net/http介绍 Go语言内置的net/http包提供了HTTP客户端和服务端的 ...
- MegEngine 框架设计
MegEngine 框架设计 MegEngine 技术负责人许欣然将带了解一个深度学习框架是如何把网络的定义逐步优化并最终执行的,从框架开发者的视角来看待深度学习. 背景 AI 浪潮一波又一波,仿佛不 ...
- 从PyTorch到ONNX的端到端AlexNet
从PyTorch到ONNX的端到端AlexNet 这是一个简单的脚本,可将Torchvision中定义的经过预训练的AlexNet导出到ONNX中.运行一轮推理Inference,然后将生成的跟踪模型 ...
- 教你三种jQuery框架实现元素显示及隐藏动画方式
摘要:在jQuery框架中对元素对象进行显示和隐藏有三种方式,分别是"默认方式显示和隐藏"."滑动方式显示和隐藏"."淡入淡出显示和隐藏". ...
- QT基本数据类型
因为Qt是一个C++框架, 因此C++中所有的语法和数据类型在Qt中都是被支持的, 但是Qt中也定义了一些属于自己的数据类型, 下边给大家介绍一下这些基础的数类型. QT基本数据类型定义在#inclu ...
- 1、java语言概述
Java基础知识图解 软件开发 软件开发 软件,即一系列按照特定顺序组织的计算机数据和指令的集合.有系统软件和应用软件之分. 人机交互方式 图形化界面(Graphical User Interface ...
- 【NX二次开发】属性操作相关函数的使用方法
内容包括:1.属性创建2.判断属性是否存在3.读取属性值4.时间属性转换成字符串5.统计属性的数量6.删除指定属性7.删除全部属性效果: 源码: #include <stdlib.h> # ...
- NoSQL:如何使用NoSQL架构构建实时广告系统
JDNoSQL平台是什么 JDNoSQL平台是一个分布式面向列的KeyValue毫秒级存储服务,存储结构化数据和非机构化数据,支持随机读写与更新,灵活的动态列机制,架构上支持水平扩容,提供高并发.低延 ...
- 面试官:MySQL的可重复读级别能解决幻读问题吗?
引言 之前在深入了解数据库理论的时候,了解到事务的不同隔离级别可能存在的问题.为了更好的理解所以在MySQL数据库中测试复现这些问题.关于脏读和不可重复读在相应的隔离级别下都很容易的复现了. 但是对于 ...
- sql数据库新建作业,新建步骤时报错从 IClassFactory 为 CLSID 为 {AA40D1D6-CAEF-4A56-B9BB-D0D3DC976BA2} 的 COM 组件创建实例失败,原因是出现以下错误: c001f011。 (Microsoft.SqlServer.ManagedDTS)
简单粗暴的重启sql数据库 其他网上找的方法 32位操作系统: 打开运行(命令提示符), 一.输入 cd c:\windows\system32 进入到c:\windows\system32路径中 二 ...