我的环境:

     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. Vue 编程式的导航

    1.应用场景 在同一路由的情况下,不同的参数之间进行切换 注意:别忘记初始化路由页面 2.用法 a.定义方法 b.实现方法 c.初始化路由页面 3.案例 <template> <di ...

  2. context:component-scan标签的诠释

    XML中配置context:component-scan时,spring会自动的扫描这个包下被这些注解标识的类@Component,@Service,@Controller,@Repository,同 ...

  3. 深入学习MySQL 03 Schema与数据类型优化

    Schema是什么鬼 schema就是数据库对象的集合,这个集合包含了各种对象如:表.视图.存储过程.索引等.为了区分不同的集合,就需要给不同的集合起不同的名字,默认情况下一个用户对应一个集合,用户的 ...

  4. CentOS7安装MySQL、Tomcat和GitBlit记录

    一.安装MySQL 1.安装这个发布包 yum localinstall mysql-community-release-el6-5.noarch.rpm 可以通过下面的命令来确认这个仓库被成功添加: ...

  5. 使用jmeter做接口测试

    1.启动jmeter. 我们可以找到Jmeter/bin 目录下的jmeter-server这个脚本,运行即可. 在下图打开的Jmeter 页面中,右键“测试计划” -> “添加” -> ...

  6. Commvault Oracle备份常用命令

    在进行Oracle数据库备份的配置.发起和恢复的过程中,需要用到许多Oracle数据库本身的命令.在此章节中进行命令的梳理,供大家参考. Oracle用户和实例相关命令 Linux/Unix平台 # ...

  7. Linux 常用工具openssh之ssh-agent

    前言 ssh-agent命令是一种控制用来保存公钥身份验证所使用的私钥的程序.ssh-agent在X会话或登录会话之初启动,所有其他窗口或程序则以客户端程序的身份启动并加入到ssh-agent程序中. ...

  8. CUDA学习(七)之使用CUDA内置API计时

    问题:对于使用GPU计算时,都想知道kernel函数运行所耗费的时间,使用CUDA内置的API可以方便准确的获得kernel运行时间. 在CPU上,可以使用clock()函数和GetTickCount ...

  9. Scala 学习(8)之「trait (2) 」

    trait调用链 Scala 中支持让类继承多个 trait 后,依次调用多个 trait 中的同一个方法,只要让多个 trait 的同一个方法中,在最后都执行super.方法即可 类中调用多个 tr ...

  10. 实验16:ACL

    实验13-1:标准ACL Ø    实验目的通过本实验可以掌握:(1)ACL 设计原则和工作过程(2)定义标准ACL(3)应用ACL(4)标准ACL 调试 Ø    拓扑结构 本实验拒绝PC1 所在网 ...