zoukankan      html  css  js  c++  java
  • (转)Django配置mysql数据库

    原文:https://zhuanlan.zhihu.com/p/105717817

    Django配置数据库有两种方法

    方法一:直接在settings.py文件中添加数据库配置信息

    DATABASES = {
        # 方法一
        'default': {
            'ENGINE': 'django.db.backends.mysql',   # 数据库引擎
            'NAME': 'mysite',                       # 数据库名称
            'USER': 'xiaohong',                      # 数据库登录用户名
            'PASSWORD': 'xiaohong',                # 密码
            'HOST': '127.0.0.1',                # 数据库主机IP,如保持默认,则为127.0.0.1
            'PORT': 3306,                           # 数据库端口号,如保持默认,则为3306
        }
    }

    方法二:将数据库配置信息存到一个文件中,在settings.py文件中将其引入。(推荐)

    新建数据库配置文件my.cnf(名字随意选择)

    [client]
    database = blog
    user = blog
    password = blog
    host =127.0.0.1
    port = 3306
    default-character-set = utf8

    在settings.py文件中引入my.cnf文件

    DATABASES = {
        # 方法二:
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'OPTIONS': {
                'read_default_file': 'utils/dbs/my.cnf',
            },
        }
    }

    启用Django与mysql的连接

    在生产环境中安装pymysql并且需要在settings.py文件所在包中的__init__.py中导入pymysql

    import pymysql
    
    pymysql.install_as_MySQLdb()

    到此mysql数据库配置完成

    如果还报错:

    pymysql报错:cryptography is required for sha256_password or caching_sha2_password

    这段报错意思是说 sha256_password 和 caching_sha2_password 这两个加密算法需要用到 cryptography 。虽然意思很明了,但是可能不知道如何解决。
    其实 cryptography 是一个python包,所以解决方法很简单:

    $ pip install cryptography
    完事。

  • 相关阅读:
    elementui表单输入框部分校验--判断
    vue学习如何引入js,封装操作localStorage本地储存的方法
    vue组件传值 递增次数传递bug修复
    vue深度监听之手机格式344
    vue-------滑动验证
    vue get/post请求如何携带cookie的问题
    elementui的dialog组件踩坑
    WebStorm License Activation (WebStorm许可证激活)
    input 标签实现带提示文字的输入框
    隐藏 input 标签的边框
  • 原文地址:https://www.cnblogs.com/liujiacai/p/15449125.html
Copyright © 2011-2022 走看看