我的环境:

     python3.6,

     Django2.1.5,

     MySQL8.0.15,

     win10,

     PyCharm,

要求:已经安装了MySQL数据库

1,安装pymysql

Django是使用MySQLdb库来连接MySQL数据库的,。但是MySQLdb不支持Python3,所以使用pymysql代替MySQLdb。
使用pip安装,然后在项目根目录的_init_.py文件中输入:import pymysql   pymysql.install_as_MySQLdb()
 
2,新建数据库
在命令行中用root登录MySQL,并输入:create database db_name default charset = utf8;
 
3,配置连接参数
在项目根目录的settings.py文件中的DATABASES参数中设置{NAME(库名), USER(登录用户), PASSWORD(用户密码), HOST(主机), PORT(端口号)},并把ENGINE改为MySQL。
如图:

 
4,设置模型(表)
Django自带了ORM,只需要在app目录的models.py文件中定义表的字段即可(例如:name = models.CharField(max_lenght=30) ),字段定义在继承了models.Model的类中。
设置表名:在该类中添加特殊类:class Meta: db_table = 'User'。注意是在类中。
如图:注意一定要加第二行,其中ShenDeng为你的项目名。

 
5,同步到数据库(生成表)
1,在命令行中:python manage.py makemigrations    # 生成数据库同步脚本。  # 在这一步可能会报错,解决方法在下面第6步。
2,在命令行中:python manage.py migrate   # 同步数据库。
 
6,错误(拒绝访问):pymysql.err.OperationalError: (1045, "Access denied for user 'root'@'localhost')
错误原因:由于MySQL的root用户默认只能由本地主机(即: localhost)访问,所以通过pymysql远程访问时会拒绝访问。
解决方法1:更改root用户的密码认证方式。在cmd中登录MySQL,并输入:alter user 'root'@'localhost' identified with mysql_native_password by 123456;
解决方法2:授权root用户远程登录。grant all on *.* to 'root'@'%' identified by 123456;
上面两种方法都可以,完成后重复步骤5即可。
 

 7,验证是否成功( 在cmd中):

       1,用root登录:mysql> mysql -u root -p; 输入密码。

       2,查看表是否存在:mysql> use <数据库名>;

                                       mysql> show tables;

      ps: 一般会有很多表,其他的暂时不用管,找到我们要建的表就行了!

8,往表中添加数据:

   新建一个.py文件输入以下内容然后单独运行就可以了。(User为继承了models.Model的类)

在Django中连接MySQL数据库(Python3)的更多相关文章

  1. django 中连接mysql数据库的操作步骤

    django中连接mysql数据库的操作步骤: 1 settings配置文件中 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mys ...

  2. Django中使用mysql数据库并使用原生sql语句操作

    Django自身默认使用sqlite3这个轻量级的数据库,但是当我们开发网站时,sqlite3就没有mysql好,sqlite3适合一些手机上开发使用的数据库. 准备的软件mysql数据库,版本5.7 ...

  3. Odoo中连接mysql数据库

    how to integrate Odoo with MySQL - Stack Overflowhttps://stackoverflow.com/questions/31959919/how-to ...

  4. Java中连接MySql数据库的例子

    Java中连接MySql数据库的例子: package com.joinmysql.demo; import java.sql.DriverManager; import java.sql.Resul ...

  5. 如何在python3环境下的Django中使用MySQL数据库

    我们在使用Django过程中,连接MySQL数据库时,对Python不同的版本对应的库也不一样,用惯了Python2的人在使用Python3时经常会遇到下面的错误: Error loading MyS ...

  6. Django中使用MySQL数据库的连接配置

    1. 安装pymysql pip install pymysql 2. 导入 # 在与 settings.py 同级目录下的 __init__.py 中引入模块和进行配置 import pymysql ...

  7. Error loading MySQLdb module: No module named 'MySQLdb'----------- django成功连接mysql数据库的方法

    在进行django学习过程中,尝试使用框架连接mysql数据库,启动服务器的时候经常遇到Error loading MySQLdb module: No module named 'MySQLdb' ...

  8. Eclipse中利用JSP把mysql-connector-java-8.0.13.jar放到WebContent\WEB-INF\lib中连接MySQL数据库时Connection conn = DriverManager.getConnection(url,username,password)报错的解决办法

    开发环境: 1.系统:windows 7/8/10均可 2.jdk:1.8.0_144 3.服务器:apache-tomcat-9.0.8 4.IDE:eclipse+jsp 0.网页代码如下: &l ...

  9. Pycharm中的Django项目连接mysql数据库

    一.安装Pycharm和Django就不详细说了,自行百度 二.新建Django项目也不说了 三.配置Django连接到mysql 1.models.py写一个类,继承models.Model cla ...

随机推荐

  1. 基于Java+HttpClient+TestNG的接口自动化测试框架(四)-------参数存取处理

    在真正开始接口测试之前,我们需要对参数的处理进行梳理.这里所说的“参数”,既包含之前在xml中的配置(我们称之为全局参数),也包含在每一条用例中书写的param.全局参数为固定不变的,而根据接口相应获 ...

  2. 异数OS 织梦师-Xnign(四)-- 挑战100倍速Nginx,脚踩F5硬件负载均衡

    . 异数OS 织梦师-Xnign(四)– 挑战100倍速Nginx,脚踩F5硬件负载均衡 本文来自异数OS社区 github: https://github.com/yds086/HereticOS ...

  3. C++符合类型:指针和引用

    1. 引用(左值引用) 引用为对象起了另外一个名字,引用类型引用另外一种类型. int ival = 1024; int &refval = ival; //refval指向ival(是iva ...

  4. SpingMvc复杂参数传收总结

    上一篇文章[javaWeb传收参数方式总结]总结了简单传收参数,这一篇讲如何传收复杂参数,比如Long[] .User(bean里面包含List).User[].List.List<Map< ...

  5. 从头开始,如何配置一部纯净好用的Windows

    emmm,原因是酱紫的, 鉴于许许多多的人问过我怎么重装系统,装出来的系统干净没有广告什么的, 还有问为什么我的电脑这么卡,是不是要重装系统or更换设备的, 啊,更换设备的土豪请随意

  6. Django中model的class Meta

    Class Meta 作用:使用内部类来提供一些metadata,以下列举一些常用的meta:1,abstract:如下段代码所示,将abstract设置为True后,CommonInfo无法作为一个 ...

  7. Arrays.asList()用法梳理

    Arrays.asList()用法梳理 asList概述 Arrays是java容器相关操作的工具类,asList方法将Array转换为list,是Array和List之间的桥梁. asList本质 ...

  8. markdown常用语法使用笔记+使用技巧(持续更新......)

    参考引用内容: 简书教程 一 基本语法 1. 标题 语法: 在想要设置为标题的文字前面加#来表示,一个#是一级标题,二个#是二级标题,以此类推.支持六级标题. 注:标准语法一般在#后跟个空格再写文字 ...

  9. .net core3.1 web api中使用newtonsoft替换掉默认的json序列化组件

    在微软的文档中,有着较为详细的替换教程 https://docs.microsoft.com/zh-cn/aspnet/core/web-api/advanced/formatting?view=as ...

  10. Unicode标准以及其常见的编码方案

    目录 基本概念 码位 码位的类型 编码方案 UTF-32 UTF-16 UTF-8 参考资料 Unicode标准为每一个字符提供一个唯一的数字,而不用区分平台.语言等因素. The Unicode S ...