python全栈开发之必要会的Django--单表操作

一、添加表纪录

方式一:

# create方法的返回值book_obj就是插入book表中的python葵花宝典这本书籍纪录对象
book_obj=Book.objects.create(title="python葵花宝典",state=True,price=100,publish="苹果出版社",pub_date="2012-12-12")

方式二:

book_obj=Book(title="python葵花宝典",state=True,price=100,publish="苹果出版社",pub_date="2012-12-12")
book_obj.save()

二、查询表纪录

查询API 

<1> all():                  查询所有结果    返回值一个queryset对象

book_list=Book.objects.all()
print(book_list)  # [obj1,obj2,.....]

for  obj in book_list:
    print(obj.title,obj.price)

<2> filter(**kwargs):       它包含了与所给筛选条件相匹配的对象    返回值一个queryset对象
book_list=Book.objects.filter(price=100)     # [obj1,obj2,....]
print(book_list) #<QuerySet [<Book: python红宝书>, <Book: php>]>
book_obj=Book.objects.filter(price=100).first()

ret=Book.objects.filter(title="go",price=200)
print(ret)


<3> get(**kwargs):          返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
book_obj=Book.objects.get(title="go")
book_obj=Book.objects.get(price=100)
print(book_obj.price)

<4> exclude(**kwargs):      它包含了与所给筛选条件不匹配的对象    返回值:queryset对象,排除过滤
ret=Book.objects.exclude(title="go")
print(ret)

<5> order_by(*field):       对查询结果排序    返回值:  queryset对象
ret=Book.objects.all().order_by("-id")   #-id:降序 id:升序
ret=Book.objects.all().order_by("price","id")    #当前面的条件一样了,就根据后面的排序
print(ret)

<6> reverse():              对查询结果反向排序


<8> count():                返回数据库中匹配查询(QuerySet)的对象数量。返回值: int
ret=Book.objects.all().count()
print(ret)

<9> first():                返回第一条记录
book=Book.objects.all().first()
book=Book.objects.all()[0]

<10> last():                返回最后一条记录
book=Book.objects.all().last()
book=Book.objects.all()[-1]

<11> exists():              如果QuerySet包含数据,就返回True,否则返回False
ret=Book.objects.all().exists()    #取其中一个值

if ret:
    print("ok")

<12> values(*field):        返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列
ret=Book.objects.all().values("price")
#<QuerySet [{'price': Decimal('100.00')},{'price': Decimal('100.00')},{'price': Decimal('200.00')},]>

<13> values_list(*field):   它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
 

<14> distinct():            从返回结果中剔除重复纪录(直接对all去重没有意义,主键肯定不一样)
Book.objects.all().values('price').distinct()

基于双下划线模糊查询

Book.objects.filter(price__in=[100,200,300])    #包括
Book.objects.filter(price__gt=100)    #大于
Book.objects.filter(price__lt=100)    #小于
Book.objects.filter(price__range=[100,200])    #范围内
Book.objects.filter(title__contains="python")    #内容包含
Book.objects.filter(title__icontains="python")    #忽略大小写的内容包含
Book.objects.filter(title__startswith="py")    #开头为...
Book.objects.filter(pub_date__year=2012)       #只有date类型才能这样使用

 三、删除表记录

删除方法就是 delete()。它运行时立即删除对象而不返回任何值。例如:

model_obj.delete()

你也可以一次性删除多个对象。每个 QuerySet 都有一个 delete() 方法,它一次性删除 QuerySet 中所有的对象。
例如,下面的代码将删除 pub_date 是2005年的 Entry 对象:

    Entry.objects.filter(pub_date__year=2005).delete()

在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。例如:

b = Blog.objects.get(pk=1)
# This will delete the Blog and all of its Entry objects.
b.delete()

要注意的是: delete() 方法是 QuerySet 上的方法,但并不适用于 Manager 本身。这是一种保护机制,是为了避免意外地调用 Entry.objects.delete() 方法导致 所有的 记录被误删除。如果你确认要删除所有的对象,那么你必须显式地调用:

Entry.objects.all().delete()

如果不想级联删除,可以设置为:

pubHouse = models.ForeignKey(to='Publisher', on_delete=models.SET_NULL, blank=True, null=True)

 四、修改表记录

Book.objects.filter(title__startswith="py").update(price=120)

此外,update()方法对于任何结果集(QuerySet)均有效,这意味着你可以同时更新多条记录update()方法会返回一个整型数值,表示受影响的记录条数。  

简而言之就是,先找到想要找的,然后使用update改想要改的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值