简介
ORM:
关系对象映射。定义一个类自动生成数据库的表结构。
创建数据库的时候,一般有以下几种常用数据类型:数字、字符串以及时间。
ORM分为两种:
- DB First 数据库里先创建数据库表结构,根据表结构生成类,根据类操作数据库
- Code First 先写代码,执行代码创建数据库表结构
主流的orm都是code first。django 的orm也是code first,所以学的时候,本质就分为两块:
- 根据类自动创建数据库表
- 根据类对数据库表中的数据进行各种操作
手动创建mysql数据库,例如db_Django03
1
|
create database root charset=utf8;
|
1,若想将模型转为mysql数据库中的表,需要在settings中配置:
1
2
3
4
5
6
7
8
9
10
|
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,在里面写入:
1
2
|
import pymysql
pymysql.install_as_MySQLdb()
|
*注意1,需确保配置文件中的INSTALLED_APPS中写入我们创建的app名称
1
2
3
4
5
6
7
8
9
|
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 这个路径里的文件把
1
2
|
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中进行如下配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
LOGGING = {
'version' : 1 ,
'disable_existing_loggers' : False ,
'handlers' : {
'console' :{
'level' : 'DEBUG' ,
'class' : 'logging.StreamHandler' ,
},
},
'loggers' : {
'django.db.backends' : {
'handlers' : [ 'console' ],
'propagate' : True ,
'level' : 'DEBUG' ,
},
}
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/xh-0205/p/9740666.html