如何使用codeigniter在mysql中插入多个复选框值

时间:2014-03-16 15:51:38

标签: php codeigniter

我是codeigniter的新手。我试图插入多个包含一些复选框的新闻,其中的值从数据库中循环。但我不知道我应该在控制器中为此编写什么代码。模型以插入值。任何人都可以建议或帮助我编写代码吗?

查看 - content.php

//category name
<?php foreach($result as $aresult) { ?>
    <input type="checkbox" name="category_name[]" value="<?php echo $aresult->category_name;?>" /> <?php echo $aresult->category_name;?>
<?php  } ?>

控制器 - 新闻

public function savecontent()
{         
    $data=array();
    foreach($this->input->post('category_name') as $category_name) 
    {
       $data[] = array('category_name' => $category_name);
    }
    $data['content_headline']=$this->input->post('content_headline',true);
    $this->co_model->save_content($data);
}

型号:

public function save_content($data)
{
    $this->db->insert('content',$data);
}

数据库结构:

id(auto incr.), category_name(varchar 50),  content_headline(varchar 100) 

现在应该更改为使用复选框插入多行?这里还有另一个文本框/列也插入数据库中。但是只应更改所有值的类别名称(复选框值)。

1 个答案:

答案 0 :(得分:1)

首先,您需要调整数据库结构。显然,contentcategory之间存在M:N关系。更合适的架构是:

create table content (
  id int not null auto_increment primary key,
  content_headline varchar(100) not null
  );

create table category (
  id int not null auto_increment primary key,
  caregory_name varchar(100) not null
  );

create table content_category (
  content int not null references content,
  category int not null references category,
  primary key (content,category)
  );

然后,您需要调整代码以反映新架构。

假设您从$result获得select * from category,您的观点将归结为:

<label>
  Headline:
  <input type='text' name='headline'>
</label>
<?php foreach($result as $aresult): ?>
  <label>
    <input type="checkbox" name="category[<?php echo $aresult->id; ?>]">
    <?php echo $aresult->category_name; ?>
  </label>
<?php endforeach; ?>

发布时,会为您提供如下数组:

array(
  'headline'=>'War and Peace',
  'category'=>array(
    45=>'on',
    6=>'on'
    )
  );

...其中45和6是已检查的类别ID。请注意,如果未选中任何类别,则不会定义category数组。

所以控制器变成:

public function savecontent()
  {         
  $post=$this->input->post();
  $selected_cats=(isset($post->category)?array_keys($post->category):array());
  $data=array(
    'headline'=>$post->headline,
    'category'=>$selected_cats
    );
  $this->co_model->save_content($data);
  }

最后,模特:

public function save_content($data)
  {
  $this->db->insert('content',array('content_headline',$data['headline']);
  $content=$this->db->insert_id(); // what we inserted
  foreach($data['category'] as $cat)
    $this->db->insert(
      'content_category',
      array(
        'content'=>$content,
        'category'=>$cat
        )
      );
  }