10.Django数据库操作(增删改)
插入数据
命令:create 或者 save
create用法:ModelName.objects.create(itemName="itemValue")
save用法:modelName = ModelName()
modelName.itemName = itemValue
modelName.save()
说明:create是objecet管理器(model默认管理器)的方法,save是model对象的方法
例子:
1.给Author表插入一条记录,其中name的值为 测试name(普通单表插入)
方法一:Author.objects.create(name="测试name")
方法二:author = Author()
author.name = "测试name"
author.save()
说明:分别是create和save的演示
2.给AuthorDetail表插入一条记录,记录Author表中id为1的作者细节信息(1对1关系)
# sex = models.BooleanField(max_length=1, choices=((0, '男'), (1, '女'),))
# email = models.EmailField()
# address = models.CharField(max_length=50)
# birthday = models.DateField()
# author = models.OneToOneField(Author)
方法一:AuthorDetail.objects.create(
sex=False,
email="admin@admin.com",
address="中国",
birthday="1988-1-1",
author_id=1)
方法二:Author.objects.create(name="测试name")
author = Author()
author.name = "测试name"
author.save()
AuthorDetail.objects.create(
sex=False,
email="admin@admin.com",
address="中国",
birthday="1988-1-1",
author=author)
说明:对于这种1对1或者1对多的插入,可以有两种方式,第一种就是方法一中,直接用author_id=1这种,另一种是直接传递个对象,像方法二中那样,直接传autho=author框架会自己去找到对应的id存入到数据库中,在这个例子中,是使用先创建author在把这个author保存,然后传递给authorDetail的,在实际中,该author对象也有可能是直接从数据库查出来的,只要是数据库里确实有的author对象就可以
3.插入一条Book信息(多对多)
# title = models.CharField(max_length=100)
# authors = models.ManyToManyField(Author)
# publisher = models.ForeignKey(Publisher)
# publication_date = models.DateField()
步骤1:插入Book表(写入Book中所有非Many-to-Many的字段)
book = Book()
book.title ="python学习"
book.publisher_id ="1"
book.publication_date ="2000-1-1"
book.save()
步骤2:插入Book表和Author表的关联表(处理Many-to-Many字段)
book.authors.add(Author.objects.get(id=1))
修改数据
命令:update 或者 save
例子:讲Author表中id为1的记录的name改为xiaol
save方法:
author = Author.objects.get(id=1)
author.name="xiaol"
author.save()
update方法:
Author.objects.filter(id=1).update(name="xiaol")
删除数据
命令:delete
用法:ModelName.objects.filter(param).delete()
说明:默认下delete是级联删除
例子:删除Author表中id为1的数据
Author.objects.filter(id=1).delete()
官方文档:https://docs.djangoproject.com/en/1.9/ref/models/querysets/
10.Django数据库操作(增删改)的更多相关文章
- Django数据库操作(增删改查)
Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...
- django数据库操作-增删改查-多对多关系以及一对多(外键)关系
一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model代码: class Person(models.Model); name = models.CharField('作者姓名' ...
- 转: django数据库操作-增删改查-多对多关系以及一对多(外键)关系
原文链接:http://blog.csdn.net/u010271717/article/details/22044415 一.一对多(外键) 例子:一个作者对应多本书,一本书只有一个作者 model ...
- Yii数据库操作增删改查-[增加\查询\更新\删除 AR模式]
在Yii的开发中常常需要去使用Yii的增删改查方法,这些方法又可以多次变化和组合,带来全方位的实现对数据库的处理,下面对这些方法做一些简单的整理和梳理,有遗漏或是BUG,敬请指出.灰常感谢!!! 一. ...
- Android下数据库操作——增删改查
Android下数据库第一种方式增删改查 1.创建一个帮助类的对象,调用getReadableDatabase方法,返回一个SqliteDatebase对象 2.使用SqliteDat ...
- SpringBoot 数据库操作 增删改查
1.pom添加依赖 <!--数据库相关配置--> <dependency> <groupId>org.springframework.boot</groupI ...
- django数据库的增删改查
正常启动服务安装数据库cmd命令:python manage.py makemigrations 创建用户 在pxm里面会有一个py文件..这就是生成了表结构cmd命令:python manage.p ...
- spring框架学习之--数据库操作增删改查
基于spring的NamedParameterJdbcTemplate操作数据库 首先在 resources 文件夹下添加数据库配置文件jdbc.properties 配置常用的数据库信息 consu ...
- Yii2.0数据库操作增删改查详解
1.简单查询: one(): 根据查询结果返回查询的第一条记录. all(): 根据查询结果返回所有记录. count(): 返回记录的数量. sum(): 返回指定列的总数. average(): ...
随机推荐
- 文本文件打印类库(C#)
我写了一个打印文本文件的类库,功能包含:打印预览.打印.打印时能够选择打印机.能够指定页码范围. 调用方法很easy: TextFilePrinter p = new TextFilePrinter( ...
- 为php5.6.30安装redis扩展
1.下载phpredis3.1.2 https://github.com/phpredis/phpredis/releases/tag/3.1.2 2.解压后在phpredis3.1.2目录下执行 / ...
- 我攻克了oom
BitmapFactory.Options options=new BitmapFactory.Options(); options.inJustDecodeBounds = false; ...
- <交流贴>android语音识别之科大讯飞语音API的使用
因为最近在研究语音识别,所以借鉴了一下CreAmazing网友的帖子 Android系统本身其实提供有语音识别模块,在它的APIDemo里也有关于语音识别的sample,不过经过大多开发者的真机测 ...
- 魔幻特效,慢放世界,nova 3带你玩转抖音新技能
无论是明暗相交的都市夜色, 还是鲜亮风景前的逆光美人: 无论是瞬息飘飞的叶片, 还是动如脱兔的稚子孩童…… 色彩与速度,精彩的每一刻, 华为摄影都尽在掌握! (华为手机摄影效果) 一直以来,华为的图形 ...
- HDU3351 Seinfeld 【贪心】
Seinfeld Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total S ...
- rsync客户端命令使用简介
rsync是linux下很流行的增量备份工具,也支持本地文件(夹)复制至远程,而且支持只传输增量部分,也是一个代码(程序)发布的好工具. 基本用法如下: rsync [一堆选项] 源文件(夹) 目标文 ...
- onInterceptTouchEvent和onTouchEvent调用时序(转)
onInterceptTouchEvent和onTouchEvent调用时序 onInterceptTouchEvent()是ViewGroup的一个方法,目的是在系统向该ViewGroup及其各个c ...
- python学习 05 函数switch功能
1.python没有switch功能,利用字典实现 如果用if else,可行但是效率不高
- 【转】利用Python中的mock库对Python代码进行模拟测试
出处 https://www.toptal.com/python/an-introduction-to-mocking-in-python http://www.oschina.net/transla ...