首页 > 数据库技术 > 详细

Django之数据库对象关系映射

时间:2019-07-03 20:28:13      阅读:160      评论:0      收藏:0      [点我收藏+]

 

Django ORM基本配置

到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞:

  • 创建数据库,设计表结构和字段
  • 使用 MySQLdb 来连接数据库,并编写数据访问层代码
  • 业务逻辑层去调用数据访问层执行数据库操作

django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM),django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表;

1、修改project数据库配置(程序主目录下的settings.py文件)

默认连接数据库为本地文件sqlite3:

DATABASES = {
    default: {
        ENGINE: django.db.backends.sqlite3,
        NAME: os.path.join(BASE_DIR, db.sqlite3),
    }
}

更换为指定的mysql数据库:

DATABASES = {
    default: {
        ENGINE: django.db.backends.mysql,
        NAME: mysite,   #一定要存在的数据库名
        USER: xxxx,
        PASSWORD: xxx,
        HOST: 192.168.xx.xx,
        PORT: 3306
    }
}

2、创建定义数据库表结构文件(对应app目录下的models.py文件)

生成一个简单的数据库表:

from django.db import models

# Create your models here.

class UserInfo(models.Model):

    username = models.CharField(max_length=32)
    passwd = models.CharField(max_length=64)

把对应的app名称加入到settings.py文件配置里:

INSTALLED_APPS = [
    django.contrib.admin,
    django.contrib.auth,
    django.contrib.contenttypes,
    django.contrib.sessions,
    django.contrib.messages,
    django.contrib.staticfiles,
    ‘cmdb02‘,
]

3、生成数据库表

执行下面命令:

python manage.py  makemigrations
python manage.py  migrate         # 生成数据表

注意:Django默认用的MysqlDB模块连接数据库,但在python3.x里面还没有这个模块,所有需要把连接数据库的模块改成pymsyql,修改project目录下的init.py文件

import  pymysql
pymysql.install_as_MySQLdb()

执行生成数据库表命令,遇到的问题:

  a.  django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

  解决: 找到 python_path\Lib\site-packages\django\db\backends\mysql路径下的base.py, 注释以下代码:

技术分享图片

b.  AttributeError: ‘str‘ object has no attribute ‘decode‘

解决:  找到 python_path\Lib\site-packages\django\db\backends\mysql路径下的operations.py, 修改以下代码:

 query = query.encode(errors=‘replace‘)  将decode修改为encode

c. pymysql.err.InternalError: (1049, "Unknown database ‘mysite‘")

解决: 数据库创建数据库 mysite

Django之数据库对象关系映射

原文:https://www.cnblogs.com/lhly/p/11128056.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!