zoukankan      html  css  js  c++  java
  • django ORM中的复选MultiSelectField的使用

      在django ORM的使用中,经常会出现选择的情况,例如:

    class person(odels.Model):
        sex_type = (('male',u'男'), ('female',u'女'))
        sex = models.CharField(u"性别", choices=sex_type,max_length=32)

      但并不是所有的选择都是只有一个结果的,例如

    class person(odels.Model):
        language_choices= (('chinese',u'汉语'), ('english',u'英语'),('french','法语'))
        language = models.CharField(u"使用语言", choices=language_choices,max_length=32)

      很明显,假如一个人又会汉语,又会英语,那么这个choices就不能上线我们的目的了,那么久可以使用MultiSelectField来实现了,例如

    class person(odels.Model):
        language_choices= (('chinese',u'汉语'), ('english',u'英语'),('french','法语'))
        language = MultiSelectField(u"使用语言",choices=language_choices)

      需要注意的几点:

      1:MultiSelectField不支持list_display,如果在list_display中添加MultiSelectField的项就会出现报错,所以当你想在admin页管理你的数据库资料时,不能在查看页面查看到MultiSelectField的项的内容。

      2:当你想使用form直接在前端生成编辑或查看数据库内容的页面时,MultiSelectField的项不能直接显示出来,而是需要进行特殊的处理,其格式如下(其中provider表示query对象,field表示MultiSelectField项)

    {% for value, text in providers.field.choices %}
      <div class="ui slider checkbox">
        <input id="id_providers_{{ forloop.counter0 }}" name="{{ form.providers.name }}" type="checkbox" value="{{ value }}"{% if value in checked_providers %} checked="checked"{% endif %}>
        <label>{{ text }}</label>
      </div>
    {% endfor %}

      3:在使用filter对MultiSelectField项进行查询时需要注意MultiSelectField项在数据库内存的是一个列表类型的数据,如果查询选择的项和你的查询条件完全相同的数据直接使用

    models.Person.objects.filter(language=['chinese'])

    但如果想要filter到所有选择了其中一个选项的数据(包括只选择了该选项的数据和同时选择了该选项和其他选项的数据),直接使用django提供的查询方法就不行了,那么可以使用Q语句来实现查询,其形式为()

    models.persom.objects.filter( Q(language='chinese')|Q(language__startswith='chinese,')|Q(language__endswith=',chinese')|Q(language__contains = ',chinese,')
  • 相关阅读:
    监控网页是否有变化
    设置开机自动启动进程
    nagios-调用脚本
    连接数据库出现10061错误
    小程序修改默认的radio样式
    小程序端,做类似于支付宝充值话费或流量的样式
    jq 在字符串中,去掉指定的元素
    vue 使用 proxyTable 解决跨域问题
    vue-cli 动态绑定图片失败
    vue-cli 使用 font-awesome 字体插件
  • 原文地址:https://www.cnblogs.com/CN-S/p/9204197.html
Copyright © 2011-2022 走看看