Django与MySQL数据库链接的配置问题

在配置Django与MySQL数据库链接的时候遇到过很多坑,找了半天解决方法,终于跑了起来,今天记录一下

1.首先新建Django工程,在settings.py中进行初始化配置,同时创建app01

python manage.py startapp app01

在settings.py中注册app01

2.在app01目录下的models.py中创建表

from django.db import models

# Create your models here.

class UserGroup(models.Model):
    #自增列自己写
    uid = models.AutoField(primary_key=True)
    caption = models.CharField(max_length=32, unique=True)
    ctime = models.DateTimeField(auto_now_add=True,null=True) #创建时间
    uptime = models.DateTimeField(auto_now=True,null=True)  #最近的一次更新时间
    #仅限于此种更新
    #obj = UserGroup.objects.filter(id = 1).update(caption = 'CEO') #django不支持这种方式
# obj = UserGroup.objects.filter(id = 1).first()
# obj.caption = "CEO"
# obj.save()#只有此特定条件

class UserInfo(models.Model):
    #表名:app01_userinfo
    #django会默认创建一个自增的id列,还是主键
    #创建用户名列,字符串类型,指定长度
    #基本数据类型 字符串 数字 时间 二进制
    username = models.CharField(max_length=32,blank=True,verbose_name='用户名',editable=False)
    password = models.CharField(max_length=64,help_text='pwd')
    email = models.CharField(max_length=60)
    gender = models.CharField(max_length=60, null=True)
    test =  models.URLField(max_length=19,null=True,error_messages={'invalid':'请输入密码'})

    user_type_choice = (
        (1,"超级用户"),
        (2,"普通用户"),
        (3,"学生用户"),
    )
    user_type_id = models.IntegerField(choices=user_type_choice, default=1)
    #django在生产外键的时候会在字段名字上加_id 数字   user_group 代指的是另一个表当中User_Group这个对象
    #user_group_id和user_group.uid代指的是一样的
    user_group = models.ForeignKey("UserGroup",to_field='uid',default=1,on_delete=models.CASCADE,)

3.安装链接组件,并在于工程同名的文件夹下打开__init__.py进行配置

python3系列中推荐使用pymysql

pip install pymysql

安装成功后,在于工程同名的文件夹下打开__init__.py进行配置

import pymysql
pymysql.version_info = (1, 3, 13, "final", 0) #新版本Django 兼容
pymysql.install_as_MySQLdb()

4.回到settings当中,对database进行配置

DATABASES = {
    # 'default': {
    #     'ENGINE': 'django.db.backends.sqlite3',
    #     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    # }
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': "test",
        'USER': "root",
        'PASSWORD': "lzhdsg123!",
        'HOST': "localhost",

    }
}

上面注释掉的部分是原来用于sqlite的配置,下面的是新的配置(记得要在MySQL当中创建SCHEMAS)

default当中的配置项,name要同SCHEMAS中相应的表保持一致    user和password填写你自己的账号密码

5.之后再工程目录下执行

python manage.py makemigrations
python manage.py migrate

这个过程中可能遇到这个错误提醒

这个时候,如果你保证你的user和password正确,只需要将MySQL修改密码刷新就可以了

但是我在这里遇到了坑,我的MySQL版本是8.0.11,网上找了很多改密码的命令,在MySQL的命令行下运行,但是始终提醒错误,最后才意识到是版本的问题,找到了修改密码的正确命令

use mysql;
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的密码';  
FLUSH PRIVILEGES;  

到此问题解决,重新进行数据库写入,我的表就都创建好了

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AlexGeek

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值