django中使用动态字段名来操作数据库

按以前的方法就是直接在sql语句里写各字段就行了,但django使用模型来操作数据库,就不能这样操作了
比如输入是book则过滤字段为title,输入是price则获取大于price的数据,输入author则过滤字段为关联表author中的name
可以将过滤条件组成一个字典,然后以关键字参数形式传递进去

def book_list(request, item, data):
    item_dict = {
   
        'book': 'title',
        'author': 'authors__name'
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django使用数据库视图非常简单,只需要在模型类使用Meta类的db_table属性指定视图的名称即可。下面是一个使用MySQL视图的示例: 假设我们有一个名为my_view的MySQL视图,它是基于以下SQL查询创建的: ```sql CREATE VIEW my_view AS SELECT column1, column2 FROM my_table WHERE column3 = 'value'; ``` 现在我们需要在Django访问这个视图。首先,我们需要在Django的settings.py文件配置数据库连接信息。这个过程略过。 接下来,我们可以创建一个名为MyView的模型类,用于访问这个视图: ```python from django.db import models class MyView(models.Model): column1 = models.CharField(max_length=100) column2 = models.CharField(max_length=100) class Meta: managed = False db_table = 'my_view' ``` 在这个模型类,我们定义了与视图相同的字段,并使用Meta类的managed属性将其设置为False,表示这个模型类不会被Django管理。然后,我们使用db_table属性指定视图的名称。 现在,我们就可以像使用任何其他Django模型类一样使用MyView了: ```python # 获取所有数据 my_view_data = MyView.objects.all() # 过滤数据 my_view_data_filtered = MyView.objects.filter(column1='value') ``` 这样,我们就可以在Django访问MySQL视图了。需要注意的是,由于视图是只读的,因此我们无法通过模型类来修改视图的数据。如果需要修改数据,还是需要通过原始的MySQL表来进行操作

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值