django数据库html页面,11.22 django和数据库、html页面之间的操作

静态文件配置:

默认情况下所有html文件都是放在templates文件夹内

什么是静态文件:网站所使用到的提前写的CSS、js、 第三方的前端模块 图片 都叫静态资源

默认情况下网站所用到的静态文件资源全部会放在static文件夹下

通常情况下 在static文件夹内部还会再建其他文件夹

CSS 文件夹

js 文件夹

font 文件夹

img 文件夹

Bootstrap

fontawesome

django中 需要自己手动创建静态文件存放的文件夹

STATIC_URL = ‘/static/‘ #访问静态文件资源接口前缀 通常情况下接口前缀的名字也叫static

手动开设静态文件访问资源

STATIC_URL = '/static/' # 访问静态文件资源接口前缀 通常情况下接口前缀的名字也叫static

# 手动开设静态文件访问资源

STATICFILES_DIRS = [ # 静态资源所在的文件夹路径

os.path.join(BASE_DIR,'static'), # 将static文件里面所有的资源暴露给用户

os.path.join(BASE_DIR,'static1'), # 将static文件里面所有的资源暴露给用户

# os.path.join(BASE_DIR,'static2'), # 将static文件里面所有的资源暴露给用户

]

静态文件动态绑定(****)

{% load static %}

form表单默认朝后端发的是get请求

get请求也能够携带参数

http://127.0.0.1:8000/login/?username=jason&password=jason123

特点:url?xxx=xxx&yyy=yyy

1.携带的数据不安全

2.携带的数据大小有限制

3.通常只会携带一些不是很重要的数据

action

? 1.不写 默认朝当前地址提交

? 2.只写后缀/index

? 3.写全路径

前期我们在朝后端提交post请求出现403的情况,需要去配置文件中注释掉一行

# 中间件

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

]

django后端的视图函数 默认处理的是get请求

? 无论是发get请求还是post请求 都会执行视图函数

def login(request):

print('来啦 老弟~')

return render(request,'login.html')

get请求只想拿到login页面

post请求想提交数据 然后后端做校验

如何判断当前请求方式

request.method 拿到的是字符串大写的请求方式 GET POST

def login(request):

# if request.method == 'GET':

# print('来啦 老弟~')

# print(request.method,type(request.method)) # 获取前端请求方式

# return render(request,'login.html')

# elif request.method == 'POST':

# print('post业务逻辑')

# return HttpResponse('收到了')

if request.method == "POST":

return HttpResponse('收到了')

return render(request,'login.html')

request方法初始

request.method 获取请求方式 并且纯大写的字符串

request.POST 获取用户提交的post请求数据

如何获取用户数据(******)

request.POST.get() # 默认只会获取列表最后一个元素

request.POST.getlist() # 如果你想获取列表 用getlist()

request.GET 获取用户提交的get请求数据

如何获取用户数据(******)

request.GET.get() # 默认只会获取列表最后一个元素

request.GET.getlist() # 如果你想获取列表 用getlist()

pycharm 连接数据库

django连接MySQL

必须要有两部操作

1.配置文件配置

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql', # 指定数据库类型

'NAME': 'day49', # 指定库的名字

'USER':'root', # 注意 键必须是全大写

'PASSWORD':'123qwe',

'HOST':'127.0.0.1',

'PORT':3306,

'CHARSET':'utf8'

}

}

2.主动告诉django 不要用默认的mysqldb连接 而是用pymysql

你可以在项目名下的__init__.py中书写

也可以在应用名下的__init__.py中书写

import pymysql

pymysql.install_as_MySQLdb()

django orm简介

orm 对象关系映射

类 表

对象 数据

对象.属性 字段对应的值

为什么使用orm

能够让不会数据库操作的人也能够简单方便的去操作数据库

orm的缺点

封装程度太高 有时候会出现查询效率偏低的问题

所以工作中 ,简单的用orm,复杂的 追速度 需要你手动书写sql语句

django中如何操作orm

书写模型类

去应用下的model.py中书写模型类

之后在写django项目的时候 一个django就对应一个数据库

不要出现多个项目使用同一个数据的情况

数据库迁移(同步)命令

1.python3 manage.py makemigrations # 将数据库的修改 记录到小本本上(migrations文件内)

2.python3 manage.py migrate # 将修改操作真正的同步到数据库中

上面两条命令必须是成双成对出现

只要修改了models里面跟数据库相关的代码 你就必须重新执行上面两条命令

***************************

模型表字段的增删改查

字段的修改

直接修改代码 然后执行数据库迁移命令即可(两条缺一不可)

字段的添加

# 方式1 设置默认值

email = models.EmailField(default='[email protected]') # varchar

# 方式2 允许字段为空

phone = models.BigIntegerField(null=True)

# 直接在提示中给默认值

gender = models.CharField(max_length=32)

字段的删除

直接注释掉对应的字段 然后执行数据库迁移命令即可

模型表数据的增删改查

data = models.User.objects.filter(username=username) # ]>

"""

filter返回的结果是一个"列表",里面才是真正数据对象

filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系

"""

user_list = models.User.objects.all() # models.User.objects.filter()

"""

结果是一个"列表" 里面是一个个的数据对象

"""

user_obj = models.User.objects.create(username=username,password=password)

print(user_obj,user_obj.username,user_obj.password)

# create方法会有一个返回值 返回值就是当前被创建的对象本身

models.User.objects.filter(id=edit_id).update(username=username,password=password)

"""

批量操作 会将filter查询出来的列表中所有的对象全部更新

"""

删(一般情况下不会使用)

models.User.objects.filter(id=delete_id).delete()

"""

批量操作 会将filter查询出来的列表中所有的对象全部删除

"""

原文:https://www.cnblogs.com/lidandanaa/p/11924948.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值