【问题标题】:select2 multiple values store in databaseselect2 多个值存储在数据库中
【发布时间】:2015-09-07 11:43:48
【问题描述】:

我已经成功创建了一个可搜索的下拉列表,每当我输入内容时,数据库中的数据都会出现在下拉列表中,现在我想将这些选择的多个值存储在数据库中。

我在控制器中的代码

$temp = $model->package_item = $_POST['package_item'];   
foreach($temp as $t) 
{
    $model->package_item=$t;                      
}

Package_item 是应用可搜索下拉列表的字段,我选择了多个值,现在如何将这些值保存在数据库中,这样我将有一个 id,但是针对这个 id,@ 987654323@ 将有多个值,其余属性将重复。就像下面一样。

     id------package_item------package_description------package_name
     1--------cake------------ very cheap-------------get one buy one free
     1---------candles---------- very cheap-------------get one buy one free
     1----------fireworks--------very cheap-------------get one buy one free

我正在使用select2 扩展名,这是视图文件中的代码

  $this->widget('ext.select2.ESelect2', array(
      'name' => 'package_item',
      'data' => CHtml::listData(Package::model()->findAll(), 'id', 'package_item'), //the whole available list
      'htmlOptions' => array(
           'placeholder' => ' search packge item?',
           //'options' => $options, //the selected values
           'multiple' => 'multiple',
           'style'=>'width:530px',
       ),
  ));

提前致谢

【问题讨论】:

    标签: mysql database yii jquery-select2


    【解决方案1】:

    我的第一个答案非常具有误导性,因此我将其删除并在此处再次尝试。

    您需要规划您的数据库表。我在这里提出一个建议:

    表格项目

    itemId[PK]|       name     | price |...|
         1    |       cake     | 5.00
         2    |      candles   | 2.00
         3    |     fireworks  | 10.00
         4    | expensiveStuff | 50.00
    

    packageId[PK] |     name     |     description      | price |
         1        | full package |    super cheap       | 12.00
         2        | epic package | best value for money | 55.00
    

    表格PackagesItems

    packageId[PK][FK]|itemId[PK][FK]|amount
    1 | 1 | 1
    1 | 2 | 1
    1 | 3 | 1
    2 | 1 | 2
    2 | 2 | 2
    2 | 3 | 3
    2 | 4 | 1
    

    然后您可以像这样查询您的包:
    例如SELECT itemId FROM PackagesItems WHERE packageId = 1

    这个答案的关键字是COMPOSITE PRIMARY KEY,在第三张表中可以看到:有两个主键,也是通向其他表的外键。

    使用SQL JOINS,您可以从其他两个表中检索信息。 如果您需要更多信息,请缩小您的问题范围。你到底想知道什么?

    【讨论】:

      猜你喜欢
      • 2013-07-17
      • 2012-11-26
      • 1970-01-01
      • 2014-05-18
      • 2017-01-08
      • 1970-01-01
      • 2016-03-21
      • 2010-12-02
      • 1970-01-01
      相关资源
      最近更新 更多