Djalgo基础配置方法

静态文件配置方法

  1 所有的静态文件都放在 static 文件夹下,例如Bootstrap值类的第三方库,通常 static 文件下会创建 css image js 文件,用于存放与前端相关的数据文件。

  2 Django setting文件配置。

# 静态文件配置
STATIC_URL = '/static/' # 接口前缀,跟你的静态文件夹名字没有任何关系,默认情况下这个前缀和静态文件夹名字一样。 STATICFILES_DIRS = [
    os.path.join(BASE_DIR,'static') # 这里的路径就是你静态文件夹的路径
   os.path.join(BASE_DIR,'static2') # 通常项目中会出现多个static文件夹,有些app也会有独立的static文件夹。
                        前端请求会依次查找列表中所有的静态文件路径,找到则立刻停止,没有则返回
                        404          
]

在Pytham中链接MySQL数据库的方法

    1 创建数据库

           

   2 修改配置文件

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 键必须是大写
'NAME': 'day55',
'HOST':'127.0.0.1',
'PORT':3306,
'USER':'root',
'PASSWORD':''
}
}

   3 告诉Django 用pymysql替换它默认的mysqldb模块,链接数据库。

    两种方式:1 在项目文件夹下的__init__.py 或 直接在你应用文件夹下面的__init__.py

    # 固定写法

    inport pymysql

    pymysql.install_as_MySQLdb()

   4 Django 中的ORM

    什么是orm?

    对象关系映射

       类                  》》》  表
            对象              》》》  表记录
            对象的属性   》》》 一条记录某个字段对应的值

    注意:在Django中不能自动创建库,但是可以自动创建表,一个Django项目使用一个库,不要多个Django项目共用一个库。

   5 数据库同步

    第一次链接数据库/或后期对现有表的字段做更改操作,都必须执行数据同步命令!

      同步命令:python3 manage.py makemigrations  将你的数据库变动记录到一个小本本上(并不会帮你创建表)
           python3 manage.py migration  将数据库变动正式同步到数据库中

        下方的session正式记录用户登陆状态的文件

   

使用Django ORM操作数据库数据

  新增数据

      两种方式:    第一种方式

         1  user_obj=model.User.object.create(name=username,password=password)

          第二种方式

         2  user_obj=model.User(name=username,password=password)

          user_obj.save()          

  查询数据
 
    user_list = models.User.objects.all()  # 获取user表所有的数据
    # 只要是QuerySet就可以点query查看获取到当前QuerySet对象的内部sql语句
    print(user_list.query)

    查询数据的时候注意获取的对象是一个queryset对象还是以一个数据对象

    user_query=models.User.objects.filter(id=edit_id).first # 使用first取出的就是一个数据对象了。

    #  当filter当匹配的条件不存在的时候,返回一个空的queryset对象。

      <QuerySet []> <class 'django.db.models.query.QuerySet'>

    user_obj = models.User.objects.get(id=edit_id)  # 用get可以直接获取到数据对象本身但是查询条件不    存在的情况下直接报错

  删除数据
    models.User.objects.filter(id=1).delete()  # 会将queryset所有的数据对象全部删除

研究GET 与POST请求的差别

  GET是请求,如果请求类型是GET,说明用户只想获取某项资源,所以我们将用户需要的资源响应给他就好。

  POST是提交,如果是POST请求,说明用户需要向服务器提交数据,服务器就要准备接收用户提交的数据,此时POST模式和GET模式都可以传输用户的数据,但是区别在于,POST更安全,所以此时应该选择POST。在一些不需要考虑数据安全的情况下可以使用GET模式传输数据。例如获取用户ID时。

  requeset.method 可以拿到两种请求方式,可以使用 request.POST / request.GET 的方式分别获取到请求数据的结果,数据形式是一个字典,该字典是 QueryDict 类型,可以通过对象点方法取获取到相应的value,也可以使用get()方法取值。

如果从前端提交的数据,在同一个key里包含多个值的情况(< QueryDict: {'username': ['jason',‘egon’], 'password': ['123']} >),需要使用getlist()方法才能取出全部的结果,如果是使用get()方法只能取到最后一个value。

  注意POST是提交数据,在HTML中只有 form表单中的 submit 和 botton 是有提交数据效果的。

通过Django 生成图书管理系统表

Web框架实现的最基础的流程图

Django—链接MySQL的更多相关文章

  1. Django 链接MySQL及数据操作

    Django 链接MySQL Django创建的项目自带的数据库是SQLite3,我们想要链接MySQL的话,需要更改settings.py中的配置 1.在MySQL中创建好数据库,Django项目不 ...

  2. Django链接MySQL,数据库迁移

    form表单默认是以get请求提交数据的 http://127.0.0.1:8000/login/?username=admin&password=123 action 1 不写,默认向当前地 ...

  3. 搭建Django链接MySQL流程(python2版)

    之前生成选型python3,除了用的python3的pymysql模块之外其他的都是一样的. 1.首先搭建mysql(Mariadb)数据库(单点)         安装方式分为yum安装,rpm包安 ...

  4. Django链接Mysql 8.0 出现错误(1045:Access denied for user 'root'@'localhost' (using password: NO) 的一种解决方法

    运行环境: Django版本2.0 ; Mysql 版本 8.0.11; 错误代码:  django.db.utils.OperationalError: (1045:Access denied fo ...

  5. Django 链接mysql

    第一步:settings.py DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'testdjango ...

  6. Django链接mysql数据库报错1064

    D:\PycharmProjects\autotest>python manage.py makemigrations django.db.utils.ProgrammingError: (10 ...

  7. django——django链接mysql数据库

    1.创建项目 django-admin startproject django_mysql 2.创建App python manage.py startapp app1 3.Mysql数据库配置 (1 ...

  8. HttpResponse,render,redirect,静态文件配置,request对象方法,pycharm连接MySQL,django连接MySQL,django ORM

    HttpResponse 主要用于返回字符串类型的数据 def index(request): return HttpResponse('index页面') 在页面中就会显示 index页面 rend ...

  9. Ubuntu中部署Django项目的配置与链接MySQL

    Django的简介 MVT模式的介绍创建项目的虚拟环境 本次使用的是pip安装 一.更新 sudo apt update 二.安装pip sudo apt install python3-pip 三. ...

随机推荐

  1. C#--正则匹配

    一个好用的Regex测试插件 快捷键:ctrl+ r , ctrl+ x 打开正则表达式工具 C#的正则表达式的常用的规则: [abc] 里面的每一次字符都可以进行匹配 a{2} 匹配2个a a{2, ...

  2. 开源GIS软件 1

    1. 在线地图浏览器 GMap.NET GMap.NET 是一个强大.免费.跨平台.开源的.NET控件,它在Windows Forms 和WPF环境中能够通过Google, Yahoo!, Bing, ...

  3. HDU 4362

    方程很简单 p[i][j] = min{dp[i-1][k] + |pos[i-1][k] - pos[i][k]|} + v[i][j]; 循环求值肯定TLE,主要是绝对值不方便.好吧,我真的BI了 ...

  4. GPS-Graph Processing System 改动源代码经验总结 (四)

    HamaWhite原创,转载请注明出处.欢迎大家增加Giraph 技术交流群: 228591158 本文目的:在改动GPS源代码后,具体描写叙述怎样编译和分发到各Worker节点上. 以下以Graph ...

  5. COCOS2D 学习笔记

    cc.Node.scheduleUpdate:function () * schedules the "update" method.                       ...

  6. UVALive - 6910 (离线逆序并查集)

    题意:给处编号从1~n这n个节点的父节点,得到含有若干棵树的森林:然后再给出k个操作,分两种'C x'是将节点x与其父节点所连接的支剪短:'Q a b'是询问a和b是否在同一棵树中. 题解:一开始拿到 ...

  7. mongo集群的监控(一)

    由于工作中总是遇到一些私有化部署和不同环境的mongo server异常,为了统一方便的监控其运行情况,我筛选了多个工具,最终选择了motop. motop是一款用python编写的实时监控工具,可以 ...

  8. OTA升级中关于update.zip包的一些总结【转】

    本文转载自:http://429564140.iteye.com/blog/2337165 update.zip包整理 一. update.zip包的目录结构           |----boot. ...

  9. ledisDB底层实现——本质上就是用leveldb这样的底层存储,和ssdb一样,meta里存的是hash、list等的元数据

    Hash hash可以算是一种两级kv,首先通过key找到一个hash对象,然后再通过field找到或者设置相应的值. 在ledisdb里面,我们需要将key跟field关联成一个key,用来存放或者 ...

  10. P1993 小K的农场 差分约束系统

    这个题是一道差分约束系统的裸题,什么是差分约束系统呢?就是给了一些大小条件,然后让你找一个满足的图.这时就要用差分约束了. 怎么做呢?其实很简单,就是直接建图就好,但是要把所有条件变为小于等于号,假如 ...