我的Mysql中已经有了项目需要使用的相关数据库,现在需要通过django来获取Mysql里的数据并使用,下面记录配置django与mysql的连接过程。

(此处默认您已经建好了django框架,如果没有准备好django,请参照我本篇文章

https://www.jb51.net/article/249861.htm

首先需要在项目的settings.py文件中配置mysql的连接信息:把之前配置的sqlite配置信息替换。
之前默认的数据库配置信息如图,是与sqlite连接的

现在我们需要替换为自己本地的Mysql信息,并连接我的ry-vue数据库,代码如下,相应的属性需要对应自己的Mysql进行配置,如果不清楚请看接下来的图片:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': '127.0.0.1',		# 要连接的数据库ip
        'PORT': '3306',				# 数据库连接端口,一般默认为3306
        'NAME': 'ry-vue',			# 已经存在的数据库名称
        'USER': 'root',				# 用户名
        'PASSWORD': '',				# 用户密码
        'OPTIONS': {
            'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",
            }
    }
}

Mysql的相关对应信息查看过程如图:

就能看到对应的连接信息:

然后在settings.py同级目录的__init__.py文件中增加下面代码,导入mysql的配置

# coding=utf-8

import pymysql
pymysql.install_as_MySQLdb()

如图:

这时你会发现导入的pymysql有报错,这是因为我们还没有安装pymysql包,根据下图过程来进行pymysql的安装:

等安装成功后就不会报错了。

之后导入数据库中的表到django里,执行下边的命令,该命令的意思是将对应数据库的表自动生成到models.py文件中。

python manage.py inspectdb > models.py

等几秒或者刷新一下文件夹,就能在 manage.py 的下面出现一个 models.py,里面包含了已有数据库的所有表及结构。

可以看到第一个表是bank,与我的数据库ry-vue里的显示完全一样

之后把想要使用的表的 managed 都改成 True。比如我想要在django中操作scratch_choice_answer表里的信息,则需要通过类名找到该表,然后修改如图:

接着将需要用的表复制到你的程序需要使用的目录下。 如果基本上都会用到,那就复制整个文件,比如我的register只里需要用到scratch_choice_answer表里的信息,那么我就操作如下,只复制 class ScratchChoiceAnswer这部分的内容到需要的文件夹下就可以。

因为需要用到register这个app,再次确认一下此文件是否在settings注册过

等到把需要的内容复制到要使用的文件夹之后,刚刚自动生成的models.py已经没有用了,就可以删除了,注意该文件位置是在manage.py下边。
下次如果只单独使用一个表,就可以使用如下的代码进行mysql的生成,而不需要全部进行生成,代码如下,表示只生成scratch_choice_answer表里的信息。

python manage.py inspectdb scratch_choice_answer

然后只需将上图红框部分的内容复制到需要的models.py里就可以。注意要将managed 的 False 设置为 True

然后运行如下指令,该指令就是将django与数据库进行同步,可以进行增删改查操作。

python manage.py migrate

等显示OK后就可以通过django对数据库进行操作了。

(这时候刷新一下Mysql,会发现自动生成了auth_xxx和django_xxx的表,这个是django用来记录对数据库的一些操作的,就放那儿不用管,对整个项目的运行没有影响)

连接成功验证

我需要获取一下scratch_choice_answer表里的choice_id,如图

则输入代码如下:

from register.models import ScratchChoiceAnswer

answer = ScratchChoiceAnswer.objects.all().values('choice_id')
print(answer)

然后运行django,(如果这时候报错ValueError: source code string cannot contain null bytes,其实是models里的编码问题,解决方法:

运行django框架出现如下报错,我出现该问题是由于数据库编码不正确

解决方法如下:

打开models.py,将编码改为UTF-8

django运行成功后可以看到获取到Mysql里的值

大功告成!

总结

到此这篇关于django连接Mysql中已有数据库的文章就介绍到这了,更多相关django连接Mysql数据库内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

django连接Mysql中已有数据库的方法详解的更多相关文章

  1. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  2. 难以在Android和iPhone上部署Django应用程序..计划切换到PHP而不是Django

    .我是否需要学习PHP,C,Java或其他任何东西,或者只要知道django和python就可以做到这一点?

  3. Android – 将SQLite与MySQL同步的最佳方式

    参见英文答案>Synchronizingclient-serverdatabases5个我正在开发一个包含网络应用和移动应用程序的项目,该应用程序记录每日用户的数据.用户可以删除,更新他们的数据,他们可以使用许多设备插入数据.我打算这样开发:用户输入他们的数据然后插入sqlite.服务将定期启动(每5小时或每小时)以使用时间戳与MysqL同步.我确实在互联网上使用服务和时间戳搜索了一个样本,但我一

  4. android – 如何将唯一的GCM注册标识存储到MySQL中

    我正在设置GoogleCloudMessaging机制的服务器端,使用MySQL存储移动应用提供的注册ID.Google可以发出最多4k个注册码,我被迫将其存储在TEXT字段中.所有的好,到目前为止,问题是我必须处理这样的情况:>用户登录到应用程序>该应用从google请求注册ID>应用程序将新的注册ID发送到应用服务器>服务器存储该注册ID并将其链接到当前登录的用户>该用户注销并且新用户登录>应

  5. Android发送发送请求到django服务器csrf失败

    我想我的Android应用程序能够发送一些信息到我的django服务器.所以我做的Android应用程序发送一个发布请求到mysite/上传页面,django的这个页面的视图将基于post数据工作.问题是服务器对post请求的响应,关于csrf验证失败.看看这个问题,似乎我可能必须先从服务器获取一个csrf令牌,然后用该令牌做帖子但是我不知道我该怎么做.编辑:我已经发现,我可以使用视图装饰器@cs

  6. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  7. nodeJs链接Mysql做增删改查的简单操作

    本篇文章主要介绍了nodeJs链接Mysql做增删改查的简单操作,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. pycharm社区版安装django并创建一个简单项目的全过程

    社区版的pycharm跟专业版的pycharm应用差别还是不太大,下面这篇文章主要给大家介绍了关于pycharm社区版安装django并创建一个简单项目的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

  9. PHP连接MYSQL数据库的3种常用方法

    这篇文章主要介绍了PHP连接MYSQL数据库的3种常用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. PHP使用PDO创建MySQL数据库、表及插入多条数据操作示例

    这篇文章主要介绍了PHP使用PDO创建MySQL数据库、表及插入多条数据操作,结合实例形式总结分析了php基于pdo的mysql数据库创建、数据表创建以及多条数据插入操作相关实现技巧,需要的朋友可以参考下

随机推荐

  1. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  2. python数学建模之三大模型与十大常用算法详情

    这篇文章主要介绍了python数学建模之三大模型与十大常用算法详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感想取得小伙伴可以参考一下

  3. Python爬取奶茶店数据分析哪家最好喝以及性价比

    这篇文章主要介绍了用Python告诉你奶茶哪家最好喝性价比最高,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

  4. 使用pyinstaller打包.exe文件的详细教程

    PyInstaller是一个跨平台的Python应用打包工具,能够把 Python 脚本及其所在的 Python 解释器打包成可执行文件,下面这篇文章主要给大家介绍了关于使用pyinstaller打包.exe文件的相关资料,需要的朋友可以参考下

  5. 基于Python实现射击小游戏的制作

    这篇文章主要介绍了如何利用Python制作一个自己专属的第一人称射击小游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手试一试

  6. Python list append方法之给列表追加元素

    这篇文章主要介绍了Python list append方法如何给列表追加元素,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  7. Pytest+Request+Allure+Jenkins实现接口自动化

    这篇文章介绍了Pytest+Request+Allure+Jenkins实现接口自动化的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 利用python实现简单的情感分析实例教程

    商品评论挖掘、电影推荐、股市预测……情感分析大有用武之地,下面这篇文章主要给大家介绍了关于利用python实现简单的情感分析的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

  9. 利用Python上传日志并监控告警的方法详解

    这篇文章将详细为大家介绍如何通过阿里云日志服务搭建一套通过Python上传日志、配置日志告警的监控服务,感兴趣的小伙伴可以了解一下

  10. Pycharm中运行程序在Python console中执行,不是直接Run问题

    这篇文章主要介绍了Pycharm中运行程序在Python console中执行,不是直接Run问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回
顶部