[英]How to add data in database in codeigniter
有两个表。
在codeigniter中,我有一个名为submenu的控制器,视图为vwsubmenu。 在添加功能中,我必须将名称,URL和idcategory添加到子类别表中。但是在视图页面中,存在三个字段,例如一个是输入类型的text(name),输入类型的text(URL),选择类型为name的类别表中的类别。
现在,我想从名称(这是选择类型的输入)中获取类别表的ID,并插入到idcategory字段的子类别表中。 如何在codeigniter中做到这一点。
请帮忙
首先改善您的数据库结构。
CREATE TABLE IF NOT EXISTS `category` (
`idcategory` int(11) NOT NULL AUTO_INCREMENT,
`parent_id` int(11) NOT NULL,
`name` varchar(255) NOT NULL,
`url` varchar(255) NOT NULL,
PRIMARY KEY (`idcategory`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=8 ;
尝试这个 ...
http://forum.codeigniter.com/archive/index.php?thread-493.html
public function add_submenu()
{
if(isset($_REQUEST['submit']))
{
$namesubcategory=$_POST['namesubcategory'];
$urlsubcategory=$_POST['urlsubcategory'];
$parent_menu=$_POST['parent_menu'];
$a=$parent_menu;
$query = $this->db->query('Select idcategory from category where namecategory="$a"');
$row = $query->row();
$b=$row->idcategory;
$sql="insert into subcategory values('','$namesubcategory','$urlsubcategory','$b')";
$val = $this->db->query($sql,array($namesubcategory ,$urlsubcategory,$b));
redirect('admin/submenu/');
}
$arr['page'] = 'submenu';
$this->load->view('admin/vwAddSubmenu',$arr);
}
这是子菜单控制器中的添加功能
首先,您必须将数据发送到模型表单控制器
$result= $this->model_name->model_function($data);
然后您可以在模型中指定它:
public function functionName( $data){
$this->db->insert('table_name',$data);
}
在子类别视图中加载3个输入字段
idcategory
(这应该是类别表的下拉列表) 然后使用提供的设置将数据添加到数据库中。
码
加载子类别视图之前获取控制器中的category
表数据
$data['category'] = $this->Model_name->get_category();
$this->load->view('sub_category_view',$data);
在模型中
public function get_category()
{
$query = $this->db->query->("SELECT * FROM category");
$result = $query->result_array();
return $result;
}
在子类别视图中
<form method="post" action="<?php echo base_url() ?>index.php/controller/add_subcategory">
<input type="text" name="name" value="Sub Category Name">
<input type="url" name="url" value="Sub Category URL">
<select name="category">
<?php
foreach ($category as $item)
{
?>
<option id="<?php echo $item['id'] ?>"><?php echo $item['name'] ?></option>
<?php
}
?>
</select>
<input type="submit" name="submit" value="Add Sub Category">
</form>
//将子类别添加到数据库
在控制器中
public function add_subcategory()
{
if(isset($_POST['submit']))
{
$name = mysql_real_escape_string($_POST['name']);//if `mysqli` change this mysql_real_escape_string
$url = $_POST['url'];
$cat = $_POST['category'];
$result = $this->Model_name->insert_subcategory($name,$url,$cat);
if(isset($result))
{
echo 'insert successfully';
}
else
{
echo 'insert Failed';
}
}
}
在模型中
function insert_subcategory($name,$url,$cat)
{
$data = array(
'name' => $name,
'url' => $url ,
'idcategory' => $cat
);
$this->db->insert('subcategory', $data);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.