第53天:Django实现代码及配置文件、Django连接mysql及ORM介绍

基于Django实现代码

URL控制器

python 复制代码
from django.conf.urls import url
from django.contrib import admin
from app01 import views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^index/', views.index),
]

视图

python 复制代码
from django.shortcuts import render


def index(request):
    print('request')
    return render(request, 'index.html')

模板文件

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>

</head>
<body>
<h1>第一个模板文件</h1>
</body>
</html>

全局配置文件

python 复制代码
LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = False

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

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',
]

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config', # 这是全写
]

Django静态文件配置

static

python 复制代码
STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static'),
]

mycss.css

css 复制代码
h4{
    color:red;
}

myjs.js

javascript 复制代码
$('h4').click(function () {
    $(this).css("color","green");
})

insex.html

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="/static/mycss.css">
    <script src="/static/jquery-3.3.1.js"></script>

</head>
<body>
<h4>我是红色,点击变绿</h4>
</body>
<script src="/static/myjs.js"></script>
</html>

django链接数据库

配置完链接数据的代码之后,Django默认启动不起来了,原因是:内部使用的链接模块用的是mysqldb,但我们不使用这个模块,我们使用pymysql模块。

如何更换pymysql

在任意的__init__.py文件中添加一下代码

python 复制代码
import pymysql
pymysql.install_as_MySQLdb()

orm介绍

orm即对象映射模型,在Django中操作数据库就不用在写原生的SQL语句,而是使用面向对象的语法和一些方法来操作数据库。

直接编写原生sql语句会存在以下缺点:

  1. sql语句的执行效率问题:应用开发程序员需要耗费一大部分精力去优化sql语句。

  2. 数据库迁移问题:针对mysql开发的sql语句无法直接应用到oracle数据库上,一旦需要迁移数据库,便需要考虑跨平台问题。

orm在哪里书写:

models.py这个文件

数据库迁移命令

python 复制代码
python38 manage.py makemigrations
python38 manage.py migrate
相关推荐
AAA修煤气灶刘哥8 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
程序新视界9 小时前
学习MySQL绕不开的两个基础概念:聚集索引与非聚集索引
mysql
RestCloud12 小时前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
得物技术15 小时前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
xiaok16 小时前
mysql中怎么创建一个可控权限数据库账号密码给到开发者
mysql
ByteBlossom19 小时前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
玉衡子19 小时前
九、MySQL配置参数优化总结
java·mysql
-Xie-20 小时前
Mysql杂志(十六)——缓存池
数据库·mysql·缓存
玉衡子20 小时前
八、MySQL全局优化总结&MySQL8新特性
java·mysql
计算机毕业设计木哥20 小时前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计