一、Django初使用

1. 静态文件配置

  • 这里的静态文件一般指的是我们下载到本地的jQuery文件,字体文件,图片文件,图标文件,Bootstrap框架的js和cs文件等。
  • 这些文件一般都放在一个专门放静态文件的文件夹内。Django中,这个文件夹我们要手动创建习惯性的以static来命名。单独用一个static文件夹来存储他们,当然是为了更方便以后的管理。

(1)静态文件配置步骤

    1. 创建完static文件夹(在app文件夹同一目录下创建)——》
    2. settings文件配置静态文件资源接口前缀——》
    3. 配置静态资源所在的文件夹路径——》
    4. 到html文件中动态绑定静态文件资源前缀
  • 第二步和第三步实例:

    第二步:
    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文件里面所有的资源暴露给用户
    ]
  • 第四步实例

    # 在head标签内部,固定写法:
    {% load static %} # static字符后面的引号内写入从static文件夹下一级一级路径往下写,直到最后的文件
    <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}"> # static字符后面的引号内写入从static文件夹下一级一级路径往下写,直到最后的文件
    <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>

2. form表单的get和post提交方式

(1)get

  • get请求也可以携带数据,当提交方式为get时,提交时,会把用户输入、选择的数据放在链接的最后面,具体形式如下:

    例子:
    http://127.0.0.1:8000/login/?username=jason&password=jason123
    特点:url?xxx=xxx&yyy=yyy
  • get请求的特点:

    • 携带的数据不安全(会直接展示在提交地址的最后面)
    • 携带的数据大小可能有限制( Http Get方法提交的数据大小长度并没有限制,HTTP协议规范没有对URL长度进行限制。这个限制是特定的浏览器及服务器对它的限制)
    • 通常只会携带一些不是很重要的数据

(2)post

  • post请求可以携带数据,并且”隐形的“提交数据。

  • 理论上讲,POST是没有大小限制的。HTTP协议规范也没有进行大小限制,起限制作用的是服务器的处理程序的处理能力。

  • 前期我们在朝后端提交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',
    ]

(3)注意

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

  • 即使form表单的提交数据方式为post,我们只要把提交数据的地址的后缀上按照get请求携带数据的方式自定义的添加数据字符串后,Django后端的views中的功能函数的request参数同样会把该数据接收,并存放在GET键对应的值中。

3. views文件中的request参数

(1)reques参数内容

  • request参数接收的是前端发送到服务端来的数据,其数据格式是一个字典。我们可以通过request.键名的方式取到对应的值。

(2)request的方法

  1. request.method

    • 获取当前的请求方式,取到的值是全大写的字符串
  2. request.POST

    • 获取用户post请求提交的数据,得到的是一个字典数据格式。且其键值对的格式是:key:[]

    (1)request.POST.get(key)

    • 获取key对应的列表的最后一个值。

    (2)request.POST.getlist(key)

    • 获取key对应的整个列表
  3. request.GET

    • 使用方法和request.POST一模一样。

4. pycharm连接数据库

  • 就是把pycharm当做可视化工具

5. Django连接MySQL

  • 必须要有两大操作

(1)settings文件中配置连接文件

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 指定数据库类型
'NAME': 'day49', # 指定库的名字
'USER':'root', # 注意 键必须是全大写
'PASSWORD':'123qwe',
'HOST':'127.0.0.1',
'PORT':3306,
'CHARSET':'utf8'
}
}

(2)改变Django默认的连接数据库模块

  • Django默认用来连接数据库的模块是MySQLdb

  • 我们可以再项目文件夹下的__init__.py文件或者应用文件夹下的__init__.py文件中书写下面的语句。

    import pymysql
    pymysql.install_as_MySQLdb()

二、 Django的orm简介

1. orm

  • orm就是对象关系映射。

    • 类——》表
    • 对象——》表中的行数据(记录)
    • 对象点属性——》字段的属性
  • orm有什么用

    • 它封装了各个接口,通过这些接口(接口就是我们封装后的那个方法),能够让不会数据库操作的人也能够简单方便的去操作数据库。
  • orm的缺点

    • 封装程度太高,有时候会出现查询效率偏低的问题。
    • 工作中,对于简单的,可以用orm来操作,复杂的,追求速度的话,U需要我们自己手动书写SQL语句。

2. Django中如何使用orm

  • 书写模型类:取应用的models.py文件中书写模型类(就是一个个类)

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

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

3. 数据库迁移(同步)命令

  • 注意:下面两条命令必须是成双成对出现,只要修改了models里面跟数据库相关的代码 你就必须重新执行下面两条命令
1.python3 manage.py makemigrations  # 将数据库的修改 记录到小本本上(migrations文件内)

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

4. 模型表字段的增删改查

字段的增加、修改:

直接修改代码 然后执行数据库迁移命令即可(两条一条不能少)
# 方式1 设置默认值
email = models.EmailField(default='123@qq.com') # varchar
# 方式2 允许字段为空
phone = models.BigIntegerField(null=True)
# 直接在提示中给默认值
gender = models.CharField(max_length=32) 字段的删除:
直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)

5. 模型表数据的增删改查

查:

(1)有条件查询:
data = models.User.objects.filter(username=username) # data的结果: <QuerySet [<User: User object>]>
"""
filter返回的结果是一个"列表",里面才是真正数据对象
推荐使用 .first()的方法取出列表中的第一个对象,当然也支持索引取值和索引切片。
filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
"""
(2)无条件查询:
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查询出来的列表中所有的对象全部删除
"""

Django初使用的更多相关文章

  1. django初体验 学习笔记

    django环境搭建     1.安装Python     2.ipython         sudo apt-get install ipython         sudo pip instal ...

  2. Django初印象之视图(view)

    一.view的初印象 一个视图函数(类),简称视图.我们发起web请求时,返回的web响应.[大家约定成俗将视图放置在项目(project)或应用程序(app)目录中的名为views.py的文件中.] ...

  3. Django初体验——搭建简易blog

    前几天在网上看到了篇采用Django搭建简易博客的视频,好奇心驱使也就点进去学了下,毕竟自己对于Django是无比敬畏的,并不是很了解,来次初体验. 本文的操作环境:ubuntu.python2.7. ...

  4. python第十七天-----Django初体验

    Django是一个MTV框架 M:models(数据库) T:templates(放置html模版) V:views(处理用户请求) 那么传说中的MVC框架又是什么呢? M:models(数据库) V ...

  5. Django初体验(一):自定义表单提交

    注:本人使用的Django1.8.3版本进行测试 除了使用Django内置表单,有时往往我们需要自定义表单.对于自定义表单Post方式提交往往会带来由CSRF(跨站请求伪造)产生的错误"CS ...

  6. Django初体验

    为什么使用Django 快速开发 使用python 数据库ORM系统 大量内置应用 后台管理系统 admin 用户认证系统 auth 会话系统 sessions 安全性高 表单验证 SQL注入 跨站点 ...

  7. Ubuntu下Django初体验(三)——django初体验

    Django中的重要概念: 一次web访问的实质: 1. 客户发送http请求到web服务回 2. web服务器返回html页面给客户 Django概述: 1. URL配置             建 ...

  8. Ubuntu下Django初体验(二)——创建工程及应用

    一.工程目录详解 创建工程后得到如下目录: 1. manage.py 管理项目.创建数据库.启动服务器等.测试等. 查看子命令: python manage.py 启动服务器: python mana ...

  9. Ubuntu下Django初体验(一)——开发环境搭建

    一.开发 环境搭建 1. linux下一般有自带的python,如果对版本不满意,可以再自行安装. 2. 安装ipython(推荐) sudo apt-get install ipython sudo ...

随机推荐

  1. Redis 常用命令 大全

    Redis 常用命令 发现几个很好的 Redis 常用命令汇总大全网页,分享给小伙伴们~ 1.Redis 命令参考 http://redisdoc.com/string/index.html 2.W3 ...

  2. zabbix使用脚本监控

    参照:http://www.cnblogs.com/zhongkai-27/p/9984597.html

  3. mybatis 动态SQL .1

    MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句的痛苦.例如拼接时要确保不能忘记添加必要的空格,还要注意去掉 ...

  4. 【神经网络与深度学习】leveldb的实现原理

    郑重声明:本篇博客是自己学习 Leveldb 实现原理时参考了郎格科技系列博客整理的,原文地址:http://www.samecity.com/blog/Index.asp?SortID=12,只是为 ...

  5. 【VS开发】【智能语音处理】MATLAB 与 音频处理 相关内容摘记

    MATLAB 与 音频处理 相关内容摘记 MATLAB 与 音频处理 相关内容摘记 1 MATLAB 音频相关函数 1 MATLAB 处理音频信号的流程 2 音量标准化 2 声道分离合并与组合 3 数 ...

  6. flask 重定向详解

    from flask import Flask,request,redirect,url_for app = Flask(__name__) @app.route('/') def hello_wor ...

  7. C语言作业11

    问题 答案 这个作业属于那个课程 C语言程序设计 这个作业要求在哪里 https://www.cnblogs.com/galen123/p/11996995.html 我在这个课程的目标是 在学好C语 ...

  8. hibernate字段映射枚举类型

    上一篇介绍了mybatis字段映射枚举类型,这一篇给大家介绍一下hibernate字段怎么去映射枚举类型的(这只是一种参考方式,映射方法还有很多种). 还是以上篇sku表为例,sku表里一个statu ...

  9. 【7.9校内test】T1挖地雷

    (土气的名字万里挑一丫丫) 然后这个题是个递推,lz的考场想法: 3个的最好确定,先把3个的确定下来,然后从这个点往前推,从这个点往后推这么算吧qwq 然后码长:也是很nice,最关键的是,我都写的这 ...

  10. Luogu P2839 [国家集训队]middle

    题目 首先我们考虑解决中位数一类问题的常用手段:二分\(mid\),将大于等于它的设为\(1\),小于它的设为\(−1\),判断区间和是否\(\ge0\). 对于询问\(a,b,c,d\),二分完\( ...