首页 > 数据库 >配置文件的介绍,静态文件的配置,request对象请求方法,pycharm连接数据库,Django连接MySQL,Django中的ORM,ORM增删改查

配置文件的介绍,静态文件的配置,request对象请求方法,pycharm连接数据库,Django连接MySQL,Django中的ORM,ORM增删改查

时间:2023-07-27 15:47:11浏览次数:52  
标签:username models res Django django ORM print password 连接

配置文件的介绍

# 注册应用的
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config',
]

#######################################中间件########################################
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 = 'day54_dj.urls' # 根路由的文件名

##############################Django连接MySQL数据库的#################################
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}
--------------------------------------------------------------------------------

LANGUAGE_CODE = 'zh-hans' 
TIME_ZONE = 'Asia/Shanghai'

静态文件的配置

# 以登录功能为例

<form action="">
	action参数的三种情况:
    	1. 什么都不写,就是朝当前地址提交数据
        2. 要么全写:http://127.0.0.1:8000/login/?username=&password=
        3. 只写后缀
        	http://127.0.0.1:8000/login/
"""
	我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建
	我们一般把静态文件放在static文件夹中,  但是,需要我们自己手动创建出来这个文件夹
	静态文件:
		网站使用的CSS文件
		网站使用的js文件
		网站使用图片
		网站使用的第三方库文件
		jQuery、bootstrap等
			
"""

# 我们还可以针对不同的功能对static文件夹里面的问价进行拆分
css
js
img
...

# 看起来是对的,但是不能访问到
http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/js/bootstrap.min.js 

# 你之前访问的地址都可以访问到,那是因为你在后端开设了可以访问的接口(理由)
# 之所以你现在访问不到刚才的地址,是因为你在后端没有开设这样的一个可访问的接口(路由)

# Django自动的帮我们写好了这样的接口

# 访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/static/开头
STATIC_URL = '/vxcvxcvxcvxcvcx/'  # 静态文件

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

# 动态解析路径

{% load static %}

<script src="{% static 'js/jquery.min.js' %}"></script>
<link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>

request对象请求方法

request.method  # 请求方式 GET POST
print(request.POST) # <QueryDict: {'username': ['jason'], 'password': ['123']}>
print(request.POST.get('username'))  # ['jason'] # jason

print(request.GET)  # <QueryDict: {'username': ['jason'], 'password': ['123']}>
print(request.GET.get('username'))  # ['jason'] # jason

pycharm连接数据库

# pycharm它也支持连接数据,Navicat连接数据库,大多数都是使用Navicat

Django连接MySQL

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

# 连接MySQL

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

# 解决bug的思路:
1. 就是print()
2. 看是否有日志
3. 看报错的信息去百度中搜索
4. 问问别人

# 连接MySQL数据的时候可能报错的解决办法:
1. 如果解释器版本导致的问题,直接改源码
def get_new_connection(self, conn_params):
    conn = Database.connect(**conn_params)
    conn.encoders[SafeText] = conn.encoders[six.text_type]
    # 先判断bytes是否存在于编码器中,如果在才执行操作
    if bytes in conn.encoders: # 加上这句话
        conn.encoders[SafeBytes] = conn.encoders[bytes]
    return conn

2. 解释器版本改为3.6的时候也会报错
Django的底层默认使用的是mysqldb模块,这个模块兼容性很差
# 我们还使用pymysql连接mysql,你要提前安装pymysql模块
Did you install mysqlclient or MySQL-python?

# 怎么解决这个问题:
在项目的任意的__init__.py中加入下面两行代码
*****************************************************************************
import pymysql
pymysql.install_as_MySQLdb()  # 猴子补丁
# 这两行代码的意思就是把底层的mysqldb模块换成pymysql
*****************************************************************************

3. 除了使用mysqldb、pymysql之外还可以使用mysqlclient这个模块
# 你用了mysqlclient这个模块,就不用加上面那两句话了
# mysqlclient安装的时候可能会报各种错误
------------------------------------------------------------------------------
# Django连接MySQL模版
#默认版本
DATABASES = {
    # 'default': {
    #     'ENGINE': 'django.db.backends.sqlite3',  # 自带的
    #     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    # }

#我们需要的版本:

    'default': {
        'ENGINE': 'django.db.backends.mysql',  # 我们连接的数据库
        'NAME': 'db9',  # 库名
        'HOST': '127.0.0.1',  # ip
        'PORT': 3306,     # 端口
        'USER': 'root',  # 用户名
        'PASSWORD': 'root',   # 密码
        'CHARSET': 'utf8'    # 编译格式
    }
}
------------------------------------------------------------------------------

Django中的ORM

什么是ORM:对象映射模型
# 以后在django中写根数据库相关的代码时候,就不用再写原生的SQL语句了,直接通过python代码来操作数据的增删改查.

# orm的书写位置:在models.py中书写
# 概念
表				>>>>>     类名

记录				>>>>>    对象

字段				>>>>>    属性

# 创建出来一张表来
# 所有的类必须继承models.Model
class User(models.Model):  # 表名
    # id int primary key auto_increment
    id = models.AutoField(primary_key=True)
    # username varchar(64)
    username = models.CharField(max_length=64)
    # password varchar(64)
    password = models.CharField(max_length=64)
    
# 类写完之后,一定要做数据库迁移,真正的在数据库中生成表
********************************************************************************
    python36 manage.py makemigrations  # 它的作用是把数据库的迁移记录保存下来
    python36 manage.py migrate		   # 才是真正的把数据表创建出来
********************************************************************************

ORM增删改查字段

class Author(models.Model):
    '''如果你创建的表中有主键字段,并且,主键字段的名字也叫id,那么,以后你就可以直接省略id字段'''
    name = models.CharField(max_length=64)
    # password1 = models.CharField(max_length=128, null=True)
    # password1 = models.CharField(max_length=64, default='12')
    

orm增删改查数据

 # 如何做查询  select * from author where username = jack and password = 123
    # objects:小组件,里面封装了很多的方法
    # res=models.Author.objects.filter(name=username, password=password).all() # 是and查询
    # res=models.Author.objects.filter(name=username, password=password) # 是and查询
    # res=models.Author.objects.filter(name=username).filter(password=password)# 是and查询
    # res=models.Author.objects.filter(name=username, password=password).first() # 是and查询

    res=models.Author.objects.create(name=username,password=password)
    # print(res)  # <QuerySet [<Author: Author object>]>  QuerySet对象以后可以点出来很多的方法
    # print(res)  # Author object  QuerySet对象以后可以点出来很多的方法
    # print(res[0].name)
    # print(res[0].password)
    # print(res.name)
    # print(res.password)

标签:username,models,res,Django,django,ORM,print,password,连接
From: https://www.cnblogs.com/huangchunfang/p/17585146.html

相关文章

  • Dapper vs Entity Framework: 你应该选择哪一个 ORM 工具?
    对象关系映射(ORM)是一种常见的技术,用于将应用程序中的对象映射到数据库中的表格。它减少了与数据库交互所需的重复代码量,并使编写易于维护的代码更加容易。在.NET中的ORM工具中,最著名的两个工具是Dapper和EntityFramework。本文将比较这两个工具,并根据您的特定需求帮助您......
  • Profinet转EtherNet/IP网关连接AB PLC的应用案例
    西门子S7-1500PLC(profinet)与ABPLC以太网通讯(EtherNet/IP)。本文主要介绍捷米特JM-EIP-PN的Profinet转EtherNet/IP网关,连接西门子S7-1500PLC与ABPLC 通讯的配置过程,供大家参考。1, 新建工程:运行 RSLogix5000 程序,选择菜单 File->New,弹出对话框:  2, 在“Type”中选......
  • 3389远程桌面连接时出现由于没有远程桌面授权服务器可以提供许可证
    原文:https://baijiahao.baidu.com/s?id=1738037840846148087&wfr=spider&for=pc 远程桌面连接出现由于没有远程桌面授权服务器可以提供许可证,远程会话被中断,请跟服务器管理员联系,怎么办呢?  首先确认你的操作系统  比如小编的是windowsserver2018年 ......
  • linux查询tcp连接数并排序
    查询已连接[root@rabbitmq-1rabbitmq]#netstat-an|awk'{print$5}'|cut-d:-f1|sort|uniq-c|sort-rn3393172.16.229.2532995172.16.47.212400172.16.229.232186172.16.229.254149172.16.229.240102172.16.229.218这个......
  • gorm使用Save方法处理时间字段的坑
    视频地址Gorm中Save方法处理时间字段的坑测试代码以及说明packagegorm_testsimport("fmt""github.com/stretchr/testify/require""gorm.io/driver/mysql""gorm.io/gorm""testing""time")const......
  • Vision Transformer
    VisionTransformer本文关注ViT论文4.5InspectingVisionTransformer可视化的原理及实现,此外还对ViTpytorch源码实现进行理解目录IntroductionTitleUsageMethodOverviewInputEncoderOutputExperimentsExplainabilityVisualizeFiltersofLinearEmbeddingVisualizePositon......
  • Kafka集群数据同步 MirrorMaker详解
    1、什么是MirrorMaker?MirrorMaker是Kafka附带的一个用于在Kafka集群之间制作镜像数据的工具。该工具主要作用是从源集群中消费并生产到目标集群。一个集群可以启动多个MirrorMaker配置到多个Kafka集群;2、如果想在Kafka测试集群,同步线的Kafka数据,做测试使用1、在测试集群配置mi......
  • 长连接:chatgpt流式响应背后的逻辑
    一、前言:提起长连接,我们并不陌生,最常见的长连接非websocket莫属了。即使没有在项目中实际用过,至少也应该有所接触。长连接指在一次网络通信中,客户端与服务器之间建立一条持久的连接,可以在多次请求和响应中重复使用该连接。这种方式的优点是减少了连接建立和关闭的开销,提高了通信......
  • 支持13系统! MacDroid pro Mac连接安卓设备 安卓文件传输工具
    太棒了。。。MacDroid终于支持13系统了!!MacDroid是一款可以让你在Mac电脑上访问和管理Android设备的软件。它可以通过USB连接,让你在Mac上浏览Android设备上的文件,包括照片、音乐、视频、文档等等。同时,它也支持将文件从Mac传输到Android设备上。此外,它还可以让你在Mac上备份和......
  • goole-java-format
    使用GoogleJavaFormat概述在本文中,我将教会你如何使用GoogleJavaFormat。GoogleJavaFormat是一个用于自动格式化Java代码的工具,可以帮助开发者编写符合Google代码风格指南的代码。通过使用GoogleJavaFormat,你可以减少手动调整代码格式的工作量,提高代码的可读性和一致性。......