django整合原有的mysql数据库

虽然django适合从零开始构建一个项目,但有时候整合原有的数据库也在所难免,下面以django整合我的mysql作说明。

mysql数据是我从京东上抓取的数据,数据表名为jd,演示如图

下面将jd整合到django中,操作如下

1.修改settings.py

[email protected]:/home/jd# vim jd/settings.py
...
DATABASES = {
    ‘default‘: {
        ‘ENGINE‘: ‘django.db.backends.mysql‘,
        #‘NAME‘: os.path.join(BASE_DIR, "jd.sql"),
        ‘NAME‘:‘jd‘,
        ‘HOST‘:‘127.0.0.1‘,
        ‘PORT‘:3306,
        ‘USER‘:‘root‘,
        ‘PASSWORD‘:‘hehe‘,
    }
}
...

2.针对已有数据库自省生成新的models

[email protected]:/home/jd# python manage.py inspectdb
# This is an auto-generated Django model module.
# You‘ll have to do the following manually to clean this up:
#   * Rearrange models‘ order
#   * Make sure each model has one field with primary_key=True
#   * Remove `managed = False` lines if you wish to allow Django to create, modify, and delete the table
# Feel free to rename the models, but don‘t rename db_table values or field names.
#

▽
# You‘ll have to do the following manually to clean this up:
# Also note: You‘ll have to insert the output of ‘django-admin.py sqlcustom [app_label]‘
# into your database.
from __future__ import unicode_literals

from django.db import models

class Jd(models.Model):

▽
    id = models.IntegerField(primary_key=True)  # AutoField?

▽
    category = models.CharField(max_length=64, blank=True)

▽
#   * Make sure each model has one field with primary_key=True
    name = models.CharField(max_length=128, blank=True)
    price = models.CharField(max_length=64, blank=True)
    url = models.CharField(max_length=64, blank=True)

    class Meta:
        managed = False
        db_table = ‘jd‘
[email protected]:/home/jd#

3.导出模型并代替models.py

[email protected]:/home/jd# python manage.py inspectdb > models.py
[email protected]:/home/jd# ls
jd  main  manage.py  models.py
[email protected]:/home/jd# mv models.py main/

4.默认配置下生成不可修改/删除的models,修改meta class中的managed=True则告诉django可以对数据库进行操作

[email protected]:/home/jd# python manage.py migrate
Operations to perform:
  Apply all migrations: admin, contenttypes, auth, sessions
Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying sessions.0001_initial... OK
[email protected]:/home/jd# python manage.py shell
Python 2.7.6 (default, Mar 22 2014, 22:59:56)
Type "copyright", "credits" or "license" for more information.

IPython 1.2.1 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython‘s features.
%quickref -> Quick reference.
help      -> Python‘s own help system.
object?   -> Details about ‘object‘, use ‘object??‘ for extra details.

5.是不是真的可以操作原有数据库了呢?进行验证即可

[email protected]:/home/jd# python manage.py shell
Python 2.7.6 (default, Mar 22 2014, 22:59:56)
Type "copyright", "credits" or "license" for more information.

IPython 1.2.1 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython‘s features.
%quickref -> Quick reference.
help      -> Python‘s own help system.
object?   -> Details about ‘object‘, use ‘object??‘ for extra details.

In [1]: from main.models import Jd

In [2]: Jd.objects.all()
Out[2]: [<Jd: 雅克菱正畸保持器清洁片 3g*24片>, <Jd: 洁灵中药漱口水  320ml(清除异味 清新口气)冬青薄荷型>, <Jd: 静佳JPlus 羽泉三秒钟酷感口腔喷雾 清新口气>, <Jd: 雅克菱假牙清洁片60片 薄荷味口气清新剂>, <Jd: 澳多-C(Victoria-C) 漱口水冰蓝超爽口味600ml>, <Jd: 保丽净假牙清洁片局部假牙专用30片>, <Jd: 李施德林漱口水500ml*3(天然橙味 清凉口味 冰蓝口味)>, <Jd: saky舒客舒克专业清新漱口水天然鲜橙380ml送120ml去口臭不含氟>, <Jd: 保丽净全/半口假牙专用假牙清洁片30片>, <Jd: 李施德林漱口水 天然橙味250ml*5 防蛀牙固齿去除口臭口气 刺激性小>, <Jd: saky舒客舒克漱口水清凉薄荷380ml送120ml 去口臭>, <Jd: 保丽净假牙全口清洁片60片 24片 加送牙盒牙刷>, <Jd: 保丽净假牙护理套装(清洁片60片) 舒适达专业修复牙膏100g>, <Jd: LION狮王 ETIQUETTE清新口喷5ml*2支 清凉薄荷>, <Jd: 皓齿健(Hosjam) 芨效抗敏漱口水500ml>, <Jd: 好易康生物酶漱口水 去除口气口臭牙龈出血牙周炎 杀菌防蛀 薄荷味 250ML>, <Jd: 保丽净假牙清洁片30片*2盒>, <Jd: 香港版 李施德林 淡香草 漱口水1000ml 除口臭 清新口气 去牙渍>, <Jd: 除口臭漱  2瓶装  口水液喷剂口气清新剂口喷雾口腔溃疡喷雾剂口苦口干>, <Jd: 日本狮王(Lion) ETIQUETTE清新口喷(清凉薄荷) 5ml 原装进口>, ‘...(remaining elements truncated)...‘]
时间: 2024-10-13 07:07:26

django整合原有的mysql数据库的相关文章

python django 站点管理 配置mysql数据库

运行命令mysql -uroot -p进入mysql 新建一个数据库mydatabase 在/mysite/mysite目录下 编辑settings.py文件: 默认数据库为sqlite: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': 'mydatabase', } } mysql数据库配置: DATABASES = { 'default': { 'ENGINE': 'django.db.ba

Spring mvc整合mybatis基于mysql数据库实现用户增删改查及其分页显示的完整入门实例【转】

Spring mvc整合mybatis例子, 基于mysql数据库实现对用户的增.删.改.查,及分页显示的完整例子. 查询显示用户 添加用户 更新用户 官方验证: 项目截图 必须修改applicationContext.xml中mysql的配置为本地的,否则启动失败. 另外jar包多一个ehcache.jar无关紧要,删除即可. 1. 使用阿里巴巴Druid连接池(高效.功能强大.可扩展性好的数据库连接池.监控数据库访问性能.支持Common-Logging.Log4j和JdkLog,监控数据库

django中怎么使用mysql数据库的事务

Mysql数据库事务: 在进行后端业务开始操作修改数据库时,可能会涉及到多张表的数据修改,对这些数据的修改应该是一个整体事务,即要么一起成功,要么一起失败. Django中对于数据库的事务,默认每执行一句数据库操作,便会自动提交.我们需要在保存数据库操作中自己控制数据库事务的执行流程. 在Django中可以通过django.db.transaction模块提供的atomic来定义一个事务,atomic提供两种用法: 装饰器用法 from django.db import transaction

django连接多个mysql数据库

https://www.cnblogs.com/zhangxinqi/p/9094953.html 阅读目录 1.定义数据库 (1) DATABASES内部选项: (2)自定义数据库 2.同步数据库 3.自动数据库路由 (1)定义数据库路由方法类 (2)使用路由数据库 (3)生成数据表并同步数据 4.手动选择数据库 回到顶部 1.定义数据库 在django项目中, 一个工程中存在多个APP应用很常见:有时候希望不同的APP连接不同的数据库,这个时候需要建立多个数据库连接.在Django的sett

kotlin + springboot整合mybatis操作mysql数据库及单元测试

项目mybatis操作数据库参考: http://how2j.cn/k/springboot/springboot-mybatis/1649.html?p=78908 junit对controller层测试参考: https://www.cnblogs.com/PollyLuo/p/9630822.html mysql版本:5.5.62 点击下载 1.kotlin版springboot项目创建 访问https://start.spring.io/, 创建项目demo(maven + kotlin

如何用IDEA创建springboot(maven)并且整合mybatis连接mysql数据库和遇到的问题

1.New->Project 2.点击next 3.在Group栏输入组织名,Artifact就是项目名.其它选择默认就好,直接Next 4.添加依赖 5.修改您希望放项目的位置,点击finish,等待idea下载springboot项目模板和相关的依赖 项目构建完成后的目录结构 6.如果需要用mybatis连接mysql数据库 a.添加连接数据库的依赖(在pom.xml中添加以下内容,maven将自动把相关依赖放到maven仓库中,然后放到项目中) <!--连接数据库--><de

django之配置使用MySQL数据库及其兼容性问题

一.修改settings.py中的默认数据库配置 DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # } 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'bbs', 'USER': 'root', 'PASSWORD': '123456'

django新建支持中文mysql数据库

CREATE DATABASE 数据库名字 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

python——django使用mysql数据库(一)

之前已经写过如何创建一个django项目,现在我们已经有了一个小骷髅,要想这个web工程变成一个有些有肉的人,我们还需要做很多操作.现在就先来介绍如何在django中使用mysql数据库. 前提:已经拥有一个django项目.已安装MySQLdb,进入mysql创建一个新的库(注意,这里必须是新的库,如果库里已经有表,就会出问题.) 修改配置项:打开已经创建好的django项目,在INSTALLED_APPS添加自己的工程名称.修改DATABASES项中配置的内容. INSTALLED_APPS