硬盘和内存条
1.硬盘:可以永久的存储数据,缺点读取数据慢
2.内存条:断电即失效,优点读取比较快,缺点没办法永久存储
mysql是存储在硬盘里面的,redis是存储在内存里面的
mysql是关系型数据库,redis是非关系型数据库
mysql支持sql语法,redis不支持sql语法,它是key,value形式存储
sql支持事务,要么都成功,要么都失败,nosql不支持事务
1.创建数你环境
pip install virtualenv virtualenvwrapper-win 这两个包都是用于创建和管理Python虚拟环境的工具
mkvirtualenv django4env 创建虚拟环境
workon django4env 进入虚拟环境
pip install django==4.2 -i https://pypi.tuna.tsinghua.edu.cn/simple LTS 4.2版本长期维护
pip show django 测试是否安装成功
pip freeze 查看自带安装的包
pip list 查看所有包
2.创建一个Django项目
django-admin startproject HelloDjango
也可以用 工具自动创建项目
3.运行项目
python .\manage.py runserver
python .\manage.py runserver 0.0.0.0:8000
4.项目流程解释
5.修改文件连接数据库
settings.py
from pathlib import Path
import pymysql
pymysql.install_as_MySQLdb()
# 项目根路径
BASE_DIR = Path(__file__).resolve().parent.parent
# 项目密钥
SECRET_KEY = 'django-insecure-kjqclv8+%utwdboo^f2iam8s@nek#ym3#70czrgh-q=m2*(239'
# 是否为调试模式 True:表示调试模式,一般是使用开发中 False: 表示非调试模式,用于上线部署使用
DEBUG = True
# 被允许访问的域名或IP * 表示通配符,都可以访问
ALLOWED_HOSTS = ['*']
# 定义应用,比如说模块化创建应用,要自己写注册自己的应用
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'order',
]
# 中间件
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
# 根路由路径
ROOT_URLCONF = 'app.urls'
# 模板
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates'
,
'DIRS': [BASE_DIR / 'templates']
,
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
# wsgi目录
WSGI_APPLICATION = 'app.wsgi.application'
# 数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'proxy_ip', # 数据库名称
'USER': 'root', # 数据库用户名
'PASSWORD': '123456', # 数据库密码
'HOST': 'localhost', # 数据库主机地址
'PORT': '3306', # 数据库端口
}
}
# 密码验证
AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
},
]
# 国际化配置
# en-us 英语 zh-hans中文
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_TZ = True
STATIC_URL = 'static/'
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
urls.py
from django.contrib import admin
from django.urls import path,include
from order.views import *
urlpatterns = [
# 一级路由
# path('login',login_user),
# 二级路由
path('od_sys/',include('order.urls')),
path('admin/', admin.site.urls),
]
models.py
from django.db import models
# 模型model 等于 表结构
# 类属性 等于 表字段
# 对象 等于 表的一行数据
# 注意点
# 数据迁移 :model表结构发生改变,需要重新迁移数据
# 迁移的概念:就是将模型映射到数据库的过程
# 生成的迁移文件: python manage.py makemigrations
# 执行迁移:python manage.py migrate
class OrderModel(models.Model):
ip_name = models.CharField(max_length=200) # 对应sql:ip_name vachar 200
ip_status=models.BooleanField(max_length=2)
views.py
from django.shortcuts import render
from django.http import JsonResponse
from order.models import *
# 获取数据库数据,处理返回给前端格式
def get_order_all(request):
order_data = OrderModel.objects.all()
order_list = [
{
'id': order.id,
'ip_name': order.ip_name,
'ip_status': order.ip_status,
}
for order in order_data
]
return JsonResponse({'order_list': order_list})
urls.py
from django.urls import path
from order.views import *
urlpatterns = [ path('get-order-all',get_order_all,name='get_order_all'),]
需要数据迁移 迁移概念:就是将模型映射到数据库的过程,不需要初始化迁移文件夹,每个应用默认有迁移文件夹migrations
生成迁移文件: thon manage.py makemigrations
执行迁移: hon manage.py migrate