python学习——在Python3.6环境下Django连接MySQL

环境:Django 1.11,Python 3.6,MySQL 5.7

Django默认的数据库是sqlite,要想改成mysql,除了需要在setting.py中将数据库改为:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'django_start',  #数据库名
        'USER':'root',           #用户名
        'PASSWORD':'root',       #密码
        'HOST':'127.0.0.1',      #本机地址
        'PORT':'3306',           #端口

    }
}

还需要将Python与MySQL链接起来,通过mysqlclient

pip install mysqlclient

网上还有种方法,通过pymysql

pip install pymysql

但是需要在项目下的__init__.py中配置下:

import pymysql
pymysql.install_as_MySQLdb()

第一种方式成功连接,第二种未尝试过。

————————————————————————————————————
第二次添加:
在完成连接后,执行run manage.py Task

makemigrations

会弹出如下警告提示:

WARNINGS:
?: (1_8.W001) The standalone TEMPLATE_* settings were deprecated in Django 1.8 and the TEMPLATES dictionary takes precedence. You must put the values of the following settings into your default TEMPLATES dict: TEMPLATE_DIRS.

原因是版本的事情,Django 1.8之后的版本需要把TEMPLATES_DIRS中的内容放到TEMPLATES中。解决方法,在setting.py中修改:

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],   #修改处
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

并**删掉**setting.py中的最后一句:

TEMPLATE_DIRS = (os.path.join(BASE_DIR,  'templates'),)

即可。

———————————————————————————————————————————
第三次补充

当在linux系统上进行连接时,直接采用如下命令(ubuntu系统):

pip install mysqlclient

是会报错的。应该按照官方说法进行安装:

首先:

sudo apt-get install python-dev libmysqlclient-dev

其次:

sudo apt-get install python3-dev

然后才是:

pip install mysqlclient

即可。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值