我的环境:

     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. 真机调试报The executable was signed with invalid entitlements.错误

    真机运行时,提示The executable was signed with invalid entitlements.(The entitlements specified in your appl ...

  2. git 工作中实用合并分支

    合并分支 .克隆远程分支 git clone -b dev1. url .创建本地分支,并关联远程分支 git checkout -b dev_wt orgin/dev_wt .合并某分支到当前分支 ...

  3. github 删除库

    1.查看库 2.选择想要删除的库,点击setting 3.删除库

  4. 阿里巴巴Jetcache springboot使用教程

    原文地址:https://www.jianshu.com/p/03b289439de2 springboot中使用说明 jetcache原理参见:https://www.jianshu.com/p/8 ...

  5. 使用Rclone和WinFsp挂载FTP为磁盘

    介绍 Rclone:是一款的命令行工具,支持在不同对象存储.网盘间同步.上传.下载数据.官网网址:rclone.org WinFsp:是一款Windows平台下的文件系统代理软件(Windows Fi ...

  6. Kivy 自定义控件之(一)

    lableSlider1.kv文件 <LabelSlider>: orientation:'vertical' BoxLayout: MyLabelSlider: name: 'Slide ...

  7. CSS-10-内边距

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  8. 线段树+Lazy标记(我的模版)

    #include <bits/stdc++.h> using namespace std; typedef long long ll; typedef unsigned long long ...

  9. Nginx(二) 常用配置

    全局配置段 # 允许运行nginx服务器的用户和用户组 user www-data; # 并发连接数处理(进程数量),跟cpu核数保存一致: worker_processes auto; # 存放 n ...

  10. java 编程小知识点

    --------------------------------- 时间不多了,抓紧做自己喜欢的事情 1. 使用位运算 & 来判断一个数是否是奇数.偶数的速度很快 (a & 1 ) = ...