Django2配置文件、pycharm连接数据库、Django链接mysql、orm
配置文件介绍(setting.py)
注册应用的
INSTALLED_APPS
中间件
MIDDLEWARE
根路由文件名
ROOT_URLCONF
Django连接数据库的
DATABASES
语言和时间
  LANGUAGE_CODE = 'zh-hans' 
  TIME_ZONE = 'Asia/Shanghai'
静态文件的配置
以登录功能
表单(form)的属性action参数的三种情况
1.什么都不写,就是相当于当前地址提交数据
2.要么全写
3.只写后缀,会自动补全路径
 我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建
	我们一般把静态文件放在static文件夹中,  但是,需要我们自己手动创建出来这个文件夹
	  静态文件:
		    网站使用的CSS文件
		    网站使用的js文件
		    网站使用图片
		    网站使用的第三方库文件
			      jQuery、bootstrap等
还可以对static文件里面的文件j进行经一部拆分css、JS、img等
访问网站的接口
之前我们访问的网站http://127.0.0.1:8000/static/bootstrap-3.4.dist/js/bootstrap.min.js
但在Django里面访问不到,那是因为你在后端开设了可以访问的接口(理由),现在访问不到刚才的地址,是因为你在后端没有开设这样的一个可访问的接口(路由):
STATIC_URL = '/vxcvxcvxcvxcvcx/' # 静态文件(访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/static/开头)
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
默认情况下(配置文件)
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } }
连接MySQL修改(配置文件)
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': ‘db8', 'HOST':'127.0.0.1', 'PORT':3306 'USER':'root' 'PASSWORD':1234 'CHARSET':'utf8' }
解决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安装的时候可能会报各种错误
DATABASES = {
      'default': {
          'ENGINE': 'django.db.backends.mysql',
          'NAME': 'db9',
          'HOST': '127.0.0.1',
          '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')
# 如何做查询 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)
                    
                
                
            
        
浙公网安备 33010602011771号