数据库开发-Django ORM的一对多查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.联合主键问题 CREATE TABLE `employees` ( `emp_no` ) NOT NULL, `birth_date` date NOT NULL, `first_name` ) NOT NULL, `last_name` ) NOT NULL, `gender` ) ' COMMENT 'M=1, F=2', `hire_date` date NOT NULL,…
数据库开发-Django ORM的多对多查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.联合主键问题 CREATE TABLE `employees` ( `emp_no` ) NOT NULL, `birth_date` date NOT NULL, `first_name` ) NOT NULL, `last_name` ) NOT NULL, `gender` ) ' COMMENT 'M=1, F=2', `hire_date` date NOT NULL,…
数据库开发-Django ORM的单表查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查询集 1>.查询集相关概述 查询会返回结果的集,它是django.db.models.query.QuerySet类型. 它是惰性求值,和SQLAlchemy一样.结果就是查询的集. 它是可迭代对象. 惰性求值: 创建查询集不会带来任何数据库的访问,直到调用方法使用数据时,才会访问数据库.在迭代.序列 化.if语句中都会立即求值. 缓存: 每一个查询集都包含一个缓存,来最小化对数据…
数据库开发-Django ORM的数据库迁移 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一. Django 项目准备 1>.安装django包 pip install django=2.2.7 除了使用pip安装之外,还可以从网上下载Django的压缩包自行安装.在浏览器上输入下载地址:“https://www.lfd.uci.edu/~gohlke/pythonlibs/#sendkeys”,找到如下图所示对应的Django版本下载到本地后,执行“pip install…
模型类 class Book(models.Model): nid = models.AutoField(primary_key=True) title = models.CharField(max_length=32, default=None) create_time = models.DateTimeField() price = models.DecimalField(decimal_places=2, max_digits=8, default=None) publish_id = m…
1.什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的操作转化为对这些对象的操作.因此它的目的是为了方便开发人员以面向对象的思想来实现对数据库的操作. ORM映射关系: 表名 <-------> 类名 字段 <-------> 属性 表记录 <-------> 类实例对象 在python中ORM将一个Python的对象映射为数…
静态文件配置 # 1.静态文件 网站所使用的已经提前写好的文件 css文件 js文件 img文件 第三方文件 我们在存储静态文件资源的时候一般默认都是放在static文件夹下 # 2.Django静态文件配置 settings.py STATICFILES_DIRS = [ os.path.join(BASE_DIR,'static') os.path.join(BASE_DIR,'static') os.path.join(BASE_DIR,'static') ] # 3.接口前缀 STATI…
数据库N+1查询是个常见的问题,简单描述场景如下 基本场景 class Category(models.Model): name = models.CharField(max_length=30) class Article(models.Model): title = models.CharField(max_length=30) body = models.TextField() category = models.ForeignKey(Category) time    = models.…
ORM映射 什么是ORM映射?在笔者认为就是对SQL语句的封装,所写语句与SQL对应语句含义相同,使开发更加简单方便,不过也是存在弊端的,使程序运行效率下降.例如: UserInfo.objects.get(id=2) 等于 select * from user_userinfo where id=2 修改管理器(models.py) 导入新的包:from django.db import models 进行模糊查询 开始进行查找前我们先来认识filter()方法. 这是一个过滤器方法用于过滤掉…
表 class Books(models.Model): '''书籍''' id = models.AutoField(primary_key=True) name = models.CharField(verbose_name='书籍名', max_length=32)class Writer(models.Model): '''作者''' id = models.AutoField(primary_key=True) name = models.CharField(verbose_name=…