需求

models对表的增删改查

知识点

1、基础操作

1.1  增
方法一
1
models.Tb1.objects.create(c1='xx', c2='oo'#增加一条数据
1
2
dic = {'c1':'xx','c2':'oo'}
models.Tb1.objects.creat(**dic)     #可以接受字典类型数据 **kwargs
form提交的数据就是字典类型,可以直接当做参数**dic传给models增加数据。
方法二
1
2
obj = models.Tb1(c1='xx', c2='oo')
obj.save()
1.2  查
1
models.Tb1.objects.get(id=123)         # 获取单条数据,不存在则报错(不建议使用)
1
models.Tb1.objects.all()   # 获取全部,它是一个Django的查询对象;取第一条.first();取列成字典.values('username');取列成列表.value_list()
1
models.Tb1.objects.filter(name='seven') # 获取指定条件的数据
1.3  删
1
models.Tb1.objects.filter(name='seven').delete() # 删除指定条件的数据
1.4  改
1
models.Tb1.objects.filter(name='seven').update(gender='0'# 将指定条件的数据更新,均支持 **kwargs
1
2
3
obj = models.Tb1.objects.get(id=1)
obj.c1 = '111'
obj.save()                    # 修改单条数据,不常用

2、进阶操作

2.1  获取个数
1
models.Tb1.objects.filter(name='seven').count()
2.2  大于,小于
1
2
3
models.Tb1.objects.filter(id__gt=1)              # 获取id大于1的值,(两个双下划线)
models.Tb1.objects.filter(id__lt=10)             # 获取id小于10的值
models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值
2.3  in
1
2
models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in
2.4  contains
1
2
3
models.Tb1.objects.filter(name__contains="ven")
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
models.Tb1.objects.exclude(name__icontains="ven")
2.5  range
1
models.Tb1.objects.filter(id__range=[1, 2])      # 范围bettwen and 
2.6  其他类似
1
startswith,istartswith, endswith, iendswith,
2.7  order by
1
2
models.Tb1.objects.filter(name='seven').order_by('id')    # asc,从小到大排列
models.Tb1.objects.filter(name='seven').order_by('-id')   # desc,从大到小排列
2.8  limit 、offset
1
models.Tb1.objects.all()[10:20]    #分页用
2.9  group by
1
2
3
from django.db.models import Count, Min, Max, Sum    #个数,最小,最大,求和
models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num'))     #annotate=grounp by,比如id为1的num列的个数
    #SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" 1 GROUP BY "app01_tb1"."id"

详细

1、增

models.py
1
2
3
class SimpleModel(models.Model):
    username = models.CharField(max_length=64)
    password = models.CharField(max_length=64)
views.py
1
2
3
4
5
def index(request):
    dic = {"username":"user1","password":"123"}
    models.SimpleModel.objects.create(**dic)
    obj= HomeForm.ImportForm(request.POST)
    return render(request,'home/index.html',{'obj':obj})

2、查

1
2
3
4
5
6
7
8
9
10
11
12
def index(request):
    ret = models.SimpleModel.objects.all()
    print ret   #[<SimpleModel: SimpleModel object>, ]对象的列表
    print type(ret)     #<class 'django.db.models.query.QuerySet'>
    print ret.query     #SELECT "id", "username","password" FROM "app01_simplemodel"
    print models.SimpleModel.objects.all().values("username")
        #[{'username': u'user1'}, {'username': u'user2'}, {'username': u'user3'}]
    print models.SimpleModel.objects.all().values_list("id","username")
        #[(1, u'user1'), (2, u'user2'), (3, u'user3')]
        #正是form--select的格式
    obj = HomeForm.ImportForm(request.POST)
    return render(request,'home/index.html',{'obj':obj})

Django--models表操作的更多相关文章

  1. django models 数据库操作

    django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...

  2. Django—models相关操作

    一.在django后台admin管理页面添加自己增加的表结构 通过终端命令:python3 manage.py makemigrations, python3 manage.py migrate 我们 ...

  3. Django多表操作

    多表创建 创建模型 下面通过一个简单的图书管理系统,来阐述多表的创建和查询操作 在视图函数里里定义如下代码 from django.db import models class Book(models ...

  4. Django单表操作

    一.数据库相关设置 配置ORM的loggers日志: # 配置ORM的loggers日志 LOGGING = { 'version': 1, 'disable_existing_loggers': F ...

  5. django models数据库操作

    一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import models     class userinfo(models.M ...

  6. Django Models 查询操作

    1.准备数据表: from django.db import models class City(models.Model): name=models.CharField(max_length=32) ...

  7. django单表操作,增、删、改、查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

  8. django单表操作 增 删 改 查

    一.实现:增.删.改.查 1.获取所有数据显示在页面上 model.Classes.object.all(),拿到数据后,渲染给前端;前端通过for循环的方式,取出数据. 目的:通过classes(班 ...

  9. Django分表操作、聚合及FQ方法

    聚合 aggregate(*args, **kwargs) # 计算所有图书的平均价格 from django.db.models import Avg Book.objects.all().aggr ...

  10. $Django 多表操作(增删改查,基于双下划线,对象的查询) 在Python脚本中调用Django环境

    在Python脚本中调用Django环境. import osif __name__ == '__main__': os.environ.setdefault("DJANGO_SETTING ...

随机推荐

  1. EWM一个仓库号对应ERP多个PLANT的配置

    1. CIF多个DC到EWM系统,创建SCU并配置成仓 2. tx:/sapapo/loc3 对多个DC生成分配模型 3. IMG:分配仓库编号 去掉缺省的授权处理方 4. 维护SCU hierarc ...

  2. Redis安装及HA(High Availability)配置

    Redis是一种内存数据库,以KEY-VALUE(即键值对)的形式存储数据.这篇文章主要介绍的是Redis安装及配置,所以不对Redis本身作详细介绍了. 下载: http://redis.io/do ...

  3. GTD时间管理(2)---管理收集箱

    通过上面一篇文章,相信大家对GTD收集有了原理大致的了解,如果大家对收集不是很了解,可以去看一下. 当我们收集到很多想法和事情之后,在晚会的时候必须要清空收集箱,否则收集箱会堆积如山,最终收集箱成了垃 ...

  4. EF性能之关联加载

    鱼和熊掌不能兼得 ——中国谚语 一.介绍 Entity Framework作为一个优秀的ORM框架,它使得操作数据库就像操作内存中的数据一样,但是这种抽象是有性能代价的,故鱼和熊掌不能兼得.但是,通过 ...

  5. Win7任务栏图标大小调整为等宽

    打开注册表,找到HKEY_CURRENT_USER\Control Panel\Desktop\WindowMetrics,新建DWORD,输入MinWidth,大图标设为56,小图标设定为36: 参 ...

  6. find the peak value

    A peak element is an element that is greater than its neighbors. Given an input array where num[i] ≠ ...

  7. eclipse android logcat 只显示自己应用程序信息的设置方法

    1 elcipse 中往往会在logcat中显示 all message ,而这里面的信息太多,根本没有办法进行区分.如图: 2 我们想显示自己项目的 logcat .下面开始设置. 3 首先点击上面 ...

  8. “合规性”是考核IT运维的重要指标

    ITSM的绩效考核向来是一个令人头疼的问题,有时就像一团乱麻,既无章可循,又无从下手.其实,只要掌握正确的思想方法,就能拨云见日.“斩乱麻”需“快刀”,“合规性考核”就是斩ITSM绩效考核这团乱麻的快 ...

  9. CodeWarrior环境下中断使用

    对于飞思卡尔CodeWarrior的中断使用,一般有3种方法: 1.把#pragma TRAP_PROC放在中断程序前面,并把中断向量表放到*.prm. 例如: #pragma TRAP_PROC v ...

  10. [论文笔记] Legacy Application Migration to the Cloud: Practicability and Methodology (SERVICES, 2012)

    Quang Hieu Vu, Rasool Asal: Legacy Application Migration to the Cloud: Practicability and Methodolog ...