Django-基础-2-ORM】的更多相关文章

一. ORM 对象关系映射 类   ------   表 类对象   ------   记录 类属性   ------   字段 二.  连接数据库配置 1.在  setting.py 文件中重新设置  DATABASES ① 删除原有的 sqlite3配置的 DATABASES #sqlite3的配置 # DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(B…
一.定义 1.什么是ORM? ORM,即Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法. 2.ORM的优缺点 优点:摆脱复杂的SQL操作,适应快速开发:让数据结构变得简洁:数据库迁移成本更低(如从mysql->oracle) 缺点:性能较差.不适用于大型应用:复杂的SQL操作还需通过SQL语句实现 映射关系: 表名…
ORM,全称是object relation mapping.翻译过来,就是对象关系映射. 主要来学习MySQL操作,MySQL是一个软件.它的优点:1.免费 2.开源 pymysql,就是Mysql给Python提供的接口.早期的接口叫mysqldb ORM可以实现不写sql语句,就可以实现操作数据库. 核心是:用python类操作表,用对象操作记录. ORM把相应的类和属性操作,转换为sql语句,来操作数据库.它做了一个翻译的过程! ORM的优点: 不需要自己写SQL,对于类的操作,会转换成…
一.定义 1.什么是ORM? ORM,即Object-Relational Mapping(对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,这样,我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法. 2.ORM的优缺点 优点:摆脱复杂的SQL操作,适应快速开发:让数据结构变得简洁:数据库迁移成本更低(如从mysql->oracle) 缺点:性能较差.不适用于大型应用:复杂的SQL操作还需通过SQL语句实现 映射关系: 表名…
1.多表操作 添加记录: 针对一对多 book_obj=Book.objects.create(title="python葵花宝典",price=100,publishDate="2012-12-12",publish_id=1)                                      pub_obj=Publish.objects.get(pk=1)                   book_obj=Book.objects.create(t…
ORM: class Book(models.Model): title=models.CharFiled(max_length=32) 类-----------------表    #  Book------- app01_book        属性变量-----------字段  #  title------ title        属性对象-----------约束     #  models.CharFiled(max_length=32)        类实例对象---------…
django的ORM操作 之前我们知道了models.py这个文件,这个文件是用来读取数据结构的文件,每次操作数据时都走这个模块 常用字段 AutoField int自增列,必须填入参数 primary_key=True.当model中如果没有自增列,则自动会创建一个列名为id的列. IntegerField 一个整数类型,范围在 -2147483648 to 2147483647. CharField 字符类型,必须提供max_length参数, max_length表示字符长度. DateF…
首先在创建表的时候看下分析一下 1.作者表和作者详细地址表  一对一关系 理论上谁都能当主表 把Author设置成主表 au=models.OneToOneField(to='AuthorDetail',to_field='id') 主表会多个au列 用于关联 2.书和出版社 一个出版社可以出好多书 一对多关系,哪个表数据多就把关键设置哪个表中 所以publisher=models.ForeignKey(to='Publish',to_field='id',on_delete=models.CA…
################################################################## # PUBLIC METHODS THAT ALTER ATTRIBUTES AND RETURN A NEW QUERYSET # ################################################################## def all(self) # 获取所有的数据对象 def filter(self, *args,…
Django基础六之ORM中的锁和事务 本节目录 一 锁 二 事务 一 锁 行级锁 select_for_update(nowait=False, skip_locked=False) #注意必须用在事务里面,至于如何开启事务,我们看下面的事务一节. 返回一个锁住行直到事务结束的查询集,如果数据库支持,它将生成一个 SELECT ... FOR UPDATE 语句. 举个例子: entries = Entry.objects.select_for_update().filter(author=r…