详解关于Django中ORM数据库迁移的配置
2018-10-08 09:59
971 查看
ORM:
关系对象映射。定义一个类自动生成数据库的表结构。
创建数据库的时候,一般有以下几种常用数据类型:数字、字符串以及时间。
ORM分为两种:
- DB First 数据库里先创建数据库表结构,根据表结构生成类,根据类操作数据库
- Code First 先写代码,执行代码创建数据库表结构
主流的orm都是code first。django 的orm也是code first,所以学的时候,本质就分为两块:
- 根据类自动创建数据库表
- 根据类对数据库表中的数据进行各种操作
手动创建mysql数据库,例如db_Django03
create database root charset=utf8;
1,若想将模型转为mysql数据库中的表,需要在settings中配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME':'bms', # 要连接的数据库,连接前需要创建好 'USER':'root', # 连接数据库的用户名 'PASSWORD':'', # 连接数据库的密码 'HOST':'127.0.0.1', # 连接主机,默认本级 'PORT':3306 # 端口 默认3306 } }
2,需要激活我们的mysql。然后,启动项目,会报错:no module named MySQLdb 。这是因为django默认你导入的驱动是MySQLdb,可是MySQLdb 对于py3有很大问题,所以我们需要的驱动是PyMySQL 所以,我们只需要找到项目名文件下的init,在里面写入:
import pymysql pymysql.install_as_MySQLdb()
*注意1,需确保配置文件中的INSTALLED_APPS中写入我们创建的app名称
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', "book" ]
*注意2,如果报错如下:
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.3 or newer is required; you have 0.7.11.None
MySQLclient目前只支持到python3.4,因此如果使用的更高版本的python,需要修改如下:
通过查找路径C:\Programs\Python\Python36-32\Lib\site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 这个路径里的文件把
if version < (1, 3, 3): raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)
注释掉 就OK了。
*注意3,如果想打印orm转换过程中的sql,需要在settings中进行如下配置:
LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console':{ 'level':'DEBUG', 'class':'logging.StreamHandler', }, }, 'loggers': { 'django.db.backends': { 'handlers': ['console'], 'propagate': True, 'level':'DEBUG', }, } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- Django基于ORM操作数据库的方法详解
- Mysql 数据库迁移以及主从库配置详解
- 关于resin服务器下开发jpa+struts2.0+spring+hibernate+dwr的数据库表的ORM配置问题
- python-django的数据库安装及配置(orm)
- Django基于ORM操作数据库的方法详解
- 详解python django面向关系数据库的ORM对象映射系统(1)
- 关于django 数据库迁移(migrate)应该知道的一些事
- Django视图之ORM更改数据库连接——配置MySQL库
- 关于git(二)-详解不使用fork迁移备份git仓库
- discuz数据库迁移,改密码后,相关配置文件修改
- django model Foreign key usage 关系型数据库 ORM
- 关于后盾网yii框架的学习小结(6)--数据库连接配置与模型定义与后台登陆验
- Django数据库迁移
- mysql 5.5数据库主从配置步骤详解
- 数据库阿里连接池 druid配置详解
- 数据库阿里连接池 druid配置详解
- 关于Hibernate 的数据库配置
- django数据库迁移的小思考
- Linux安装配置MariaDB数据库全程详解
- Windows7下关于IIS配置问题详解