Ⅰ.django的ORM
1.含义
对象关系映射(英语:(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的--“虚拟对象数据库”。ORM有时也称为基于事实的建模,因为它把相关数据描述为基本事实。这些事实如果分割为再小的事实就会丢失信息。
对象关系映射(Object-Relational Mapping)提供了概念性的、易于理解的模型化数据的方法。ORM方法论基于三个核心原则: 简单:以最基本的形式建模数据。 传达性:数据库结构被任何人都能理解的语言文档化。 精确性:基于数据模型创建正确标准化的结构。 典型地,建模者通过收集来自那些熟悉应用程序但不熟练的数据建模者的人的信息开发信息模型。建模者必须能够用非技术企业专家可以理解的术语在概念层次上与数据结构进行通讯。建模者也必须能以简单的单元分析信息,对样本数据进行处理。ORM专门被设计为改进这种联系。
总而言之,ORM就是指:用python的概念来表达数据库。即可以用python中的数据类型来表示mysql中的一张表。也就是说,我对python的数据进行操作,它就可以将其映射到mysql的数据库中,而我不需要写sql语句。
Ⅱ.数据库配置
1.数据库配置步骤
安装pymysql
修改项目目录下的
__init__.py
,改为如下样式:
import pymysql
pymysql.install_as_MySQLdb()
手动创建一个当前项目的空的数据库,准备一个有创建数据库权限的用户
settings 配置,改为如下样式:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'crm', #数据库名
'USER': 'admin',
'PASSWORD': 'Root110qwe',
'HOST': '127.0.0.1',
'PORT': '',
}
2.实际操作
3.补充:两种数据库的创建方法
1)Navicat(物理机)的创建/连接
2)在pycharm的虚拟机中进行数据库的创建
Ⅲ.模型的创建与映射
1.模型
1)模型含义
这里的模型就 django.db.models.Model
的一个子类。
模型定义在app文件夹下的models.py
文件
2)创建模型
2.激活模型(模型映射)
1)执行步骤
**注册应用
创建迁移(django数据库中一旦有任何的数据库结构的改变都要进行一次创建迁移)
python manage.py makemigrations appname #注:如果不写 appname 则代表迁移所有已注册的app
如果想看:我们的更改,会对数据库产生什么影响,我们可以看它大概会执行什么sql语句。具体操作如下:
python manage.py sqlmigrate appname num 例如: python manage.py sqlmigrate teacher 0001
- 执行迁移 操作数据库,将对模型的改动应用到数据库(底层就是执行了sql),具体输入如下:
python manage.py migrate appname #当不写 appname 则会将所有注册的改动映射到输出
模型映射到数据库中是一张表, 表名 = appname_模型name (小写)
执行上面的命令到底干了些什么:
1.在app中查找迁移文件,并且去django_migrations表中查找,如果有没有执行的迁移文件,就执行它
2.执行了迁移生存的sql语句
3.如果成功,会在django_migrations表中增加一条记录
2)实例操作
当发生修改时,继续如下操作:
Ⅳ.简单的数据的增删改查
1.django 调试环境
python manage.py shell
2.增
1)一般代码输入情况
#第一种方式:
In [3]: s=Student()
In [5]: s.name = 'Michael_Lxh'
In [6]: s.age = 18
In [7]: Student.objects.all()
Out[7]: <QuerySet []> In [8]: s.save() # save 之后才会写到数据库 #第二种方式:
In [10]: stu = Student.objects.create(name='隔壁老王', age=20) #直接创建
2)实例操作
a.第一种方式
b.第二种方式
3.删
1)一般代码输入情况
#删某一条:
In [13]: stu.delete()
Out[13]: (1, {'teacher.Student': 1}) #删所有:
In [8]: Student.objects.all().delete() #注意:一般情况下千万不要使用(慎重) #删特定一条:
In [8]: Student.objects.filter(sex=1).delete() Out[8]: (1, {'teacher.Student': 1})
2)实例操作
a.删除特定的
4.改
1)一般代码输入情况
#改一条的情况:
In [17]: s.age=16
In [18]: s.save() #改全部条:
In [6]: Student.objects.all().update(sex=0)
Out[6]: 2 #改部分有选择的:
In [7]: Student.objects.filter(age__gt=17).update(sex=1)
Out[7]: 1
2)实例操作
a.改一条的情况
b.改全部
c.有选择的修改
5.查
1)一般代码输入情况
#查所有:
In [2]: Student.objects.all()
Out[2]: <QuerySet [<Student: Michael_Lxh>, <Student: 隔壁老王>]> #查一条:
In [3]: Student.objects.get(pk=1) #如果get返回了多值就会报错,因为get返回的是对象
Out[3]: <Student: Michael_Lxh> #带条件的查询:
In [4]: Student.objects.filter(sex=1) # 等价于 where sex=1
Out[4]: <QuerySet [<Student: Michael_Lxh>, <Student: 隔壁老王>]> In [5]: Student.objects.filter(sex=1,name='Michael_Lxh')
Out[5]: <QuerySet [<Student: Michael_Lxh>]>
2)实例操作
a.查所有
b.查一条
c.查带条件的
补充网址(mysql):https://dev.mysql.com/doc/refman/8.0/en/charset-unicode-sets.html