Python web模版Django-18 模型之增删改查操作

增删改查,基本操作: 

# 增
    #
    # models.Tb1.objects.create(c1='xx', c2='oo')  增加一条数据,可以接受字典类型数据 **kwargs

    # obj = models.Tb1(c1='xx', c2='oo')
    # obj.save()

    # 查
    #
    # models.Tb1.objects.get(id=123)         # 获取单条数据,不存在则报错(不建议)
    # models.Tb1.objects.all()               # 获取全部
    # models.Tb1.objects.filter(name='seven') # 获取指定条件的数据

    # 删
    #
    # models.Tb1.objects.filter(name='seven').delete() # 删除指定条件的数据

    # 改
    # models.Tb1.objects.filter(name='seven').update(gender='0')  # 将指定条件的数据更新,均支持 **kwargs
    # obj = models.Tb1.objects.get(id=1)
    # obj.c1 = '111'
    # obj.save()                                                 # 修改单条数据

进阶操作:

# 获取个数
        #
        # models.Tb1.objects.filter(name='seven').count()

        # 大于,小于
        #
        # models.Tb1.objects.filter(id__gt=1)              # 获取id大于1的值
        # models.Tb1.objects.filter(id__gte=1)              # 获取id大于等于1的值
        # models.Tb1.objects.filter(id__lt=10)             # 获取id小于10的值
        # models.Tb1.objects.filter(id__lte=10)             # 获取id小于10的值
        # models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值

        # in
        #
        # models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
        # models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in

        # isnull
        # Entry.objects.filter(pub_date__isnull=True)

        # contains
        #
        # models.Tb1.objects.filter(name__contains="ven")
        # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
        # models.Tb1.objects.exclude(name__icontains="ven")

        # range
        #
        # models.Tb1.objects.filter(id__range=[1, 2])   # 范围bettwen and

        # 其他类似
        #
        # startswith,istartswith, endswith, iendswith,

        # order by
        #
        # models.Tb1.objects.filter(name='seven').order_by('id')    # asc
        # models.Tb1.objects.filter(name='seven').order_by('-id')   # desc

        # group by
        #
        # from django.db.models import Count, Min, Max, Sum
        # models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num'))
        # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"

        # limit 、offset
        #
        # models.Tb1.objects.all()[10:20]

        # regex正则匹配,iregex 不区分大小写
        #
        # Entry.objects.get(title__regex=r'^(An?|The) +')
        # Entry.objects.get(title__iregex=r'^(an?|the) +')

        # date
        #
        # Entry.objects.filter(pub_date__date=datetime.date(2005, 1, 1))
        # Entry.objects.filter(pub_date__date__gt=datetime.date(2005, 1, 1))

        # year
        #
        # Entry.objects.filter(pub_date__year=2005)
        # Entry.objects.filter(pub_date__year__gte=2005)

        # month
        #
        # Entry.objects.filter(pub_date__month=12)
        # Entry.objects.filter(pub_date__month__gte=6)

        # day
        #
        # Entry.objects.filter(pub_date__day=3)
        # Entry.objects.filter(pub_date__day__gte=3)

        # week_day
        #
        # Entry.objects.filter(pub_date__week_day=2)
        # Entry.objects.filter(pub_date__week_day__gte=2)

        # hour
        #
        # Event.objects.filter(timestamp__hour=23)
        # Event.objects.filter(time__hour=5)
        # Event.objects.filter(timestamp__hour__gte=12)

        # minute
        #
        # Event.objects.filter(timestamp__minute=29)
        # Event.objects.filter(time__minute=46)
        # Event.objects.filter(timestamp__minute__gte=29)

        # second
        #
        # Event.objects.filter(timestamp__second=31)
        # Event.objects.filter(time__second=2)
        # Event.objects.filter(timestamp__second__gte=31)

实例:

继续操作前面的例子。。。 创建一个用来实验数据增删改查的简单页面,这也是我目前能力所能折腾出来的例子奋斗

step1: 在urls.py中添加两个url,他们对应views.py下新建的两个函数

    url(r'^table_edit/', views.table_edit),
    url(r'^implement_table_edit/', views.implement_table_edit)

step2:在views.py下新建两个函数

table_edit用来登录编辑页面;


 implement_table_edit实现编辑操作,用户可以输入 add 或 search 或change 或del去处理数据,具体的处理数据,为了简单起见,写死到程序中了, 只是为了实验增删改查的数据操作。

def table_edit(request):
    return render(request, "table_edit.html")


def implement_table_edit(request):
    # 获取要处理的数据
    edit_way = request.POST.get('edit_way')
    # 处理数据
    implement_message = ''
    # 插入数据
    if edit_way == "add" and list(Event.objects.filter(name='红米Pro发布会')) == []:
        print("add")
        e1 = Event(id=3, name='红米Pro发布会', limit=2000, status=True, address='北京水立方',
                   start_time=datetime(2017, 8, 10, 14, 0, 0))
        e1.save()
        implement_message = '添加《红米Pro发布会》数据'
    # 查询数据
    elif edit_way == "search":
        e1 = Event.objects.filter(name__contains='发布会')
        implement_message = "查出的发布会有: "
        for item in e1:
            print(item.name)
            implement_message += item.name
    # 编辑数据
    elif edit_way == "change" and list(Event.objects.filter(name='红米Pro发布会')) != []:
        e1 = Event.objects.get(name='红米Pro发布会')
        e1.limit = 3000
        e1.save()
        implement_message = "更新红米Pro发布会限定人数到3000"
    # 删除数据
    elif edit_way == "del" and list(Event.objects.filter(name='红米Pro发布会')) != [] :
        e1 = Event.objects.get(name='红米Pro发布会')
        e1.delete()
        implement_message = '删除《红米Pro发布会》数据'
    # 什么都不操作
    else:
        implement_message = "输入不对或红米Pro发布会数据不存在,因此未执行数据编辑"

    return render(request, "table_edit.html", {'implement_message': implement_message})

step3: 在templates文件夹下新建 table_edit.html, action关联到 implement_table_edit()函数,并输出implement_message

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Table增删改查</title>
</head>
<body>
    <h1>尝试数据记录增删改查</h1>
    <form method="post" action="/implement_table_edit/">  
        <input type="text" placeholder="input add/search/change/del" name="edit_way" ><br>
        <button type="submit" name="submit_edit_way_btn">处理数据</button><br>
        {{implement_message}}<br>
        {% csrf_token %}
     </form>
</body>
</html>


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值