Django ORM模型增删改查

Django作为python主流开发框架之一,如何实现在终端对数据进行增删改查

 --ORM模型

先在终端进入shell交互模式,在项目的根目录输入:

1、python manage.py shell                --进入shell交互模式

2、from xds.models import Pera       --从app中的模型导入类名 (Pera = 表名)

  3、增加数据:Pera.objects.create('需增加的数据')

>>> Pera.objects.create(uid=11,name='hangzhou',age=60)
<Pera: Pera object (11)>
>>> Pera.objects.create(uid=12,name='beijing',age=70)
<Pera: Pera object (12)>
会返回一个object的对象

数据库中此时新增两条数据

 4、查询数据:get的方法和filter方法

get方法:get方法的弊端:在查询的属性存在多个或者查询不到的时候会抛出异常,只适用单条数据的查询。

>>> a = Pera.objects.get(uid=11)
>>> a
<Pera: Pera object (11)>  --返回的是个object对象
>>> a.uid
11
>>> a.name
'hangzhou'
再去通过a来查询其他属性值

filter方法:能同时查询多条相同的数据

>>> b = Pera.objects.filter(name='changsha')
>>> b
<QuerySet [<Pera: Pera object (4)>, <Pera: Pera object (5)>]>   --返回的是一个QuerySet对象,两条数据
>>>

5、修改数据  

   返回object对象修改数据方式:

>>> a = Pera.objects.get(uid=11)
>>> a
<Pera: Pera object (11)>
>>> a.name='update'
>>> a.save()       -- object对象修改数据后必须要save 才能更新数据库内的数据

 返回QuerySet对象修改数据有一个update的方法   --只有返回QuerySet对象有此方法,object对象没有update的方法

>>> b = Pera.objects.filter(name='changsha')
>>> b
<QuerySet [<Pera: Pera object (4)>, <Pera: Pera object (5)>]>
>>> b.update(name='QuerySet')       --修改后不需要save 
2

 6、删除   delete

>>> a.delete()
(1, {'xds.Pera': 1})   --通过返回的object对象调用delete方法即可

 删除、修改的操作的前置条件都是基于查询后,再去做相关的变更操作

 

 

 

 

 

 

 

  

 

posted @ 2022-01-11 23:24  夏大帅  阅读(136)  评论(0编辑  收藏  举报