我正在制作表单构建器,我有一个输入字段,称为名字,姓氏,电子邮件,Iagree。无论用户从表单构建器页面选择字段,所有元素都会在单击按钮后存储在数据库中。
就像我从表单构建器页面中选择元素Firstname,Lastname,Email和iagree并保存它。在数据库中,它将存储如下例子
现在我更新表单构建器并更改表单元素。它显示如下图像。
使用以下查询我将更新最后一条记录
SELECT form_id,form_elements,form_builder_type, update_date FROM `form_builder` WHERE form_id=1 AND form_builder_type='example' ORDER BY update_date DESC LIMIT 1
以上查询的输出
现在我有第二个表,其中包含字段名称和字段类型
我必须加入这两个表来获取字段名称和元素类型。
现在我必须使用字段名称和字段类型显示表单构建器的最后一个元素。我的意思是它会显示姓氏和带有字段类型的电子邮件。
我正在使用CodeIgniter,我的控制器
$inst_id=1;
$result['data']=$this->formbuilder_Model->check_example_form_builder_fields($inst_id);
$this->load->view('user-form',$result);//passing elements to the view page
查看
foreach ($data as $key) {
$exp_fields_name=$key->fields_name;
$exp_fields_type=$key->fields_type;
$exp_form_elements=$key->form_elements;
$abc=explode(',',$exp_form_elements);
foreach ($abc as $value) {
if ($exp_fields_name == $value) {?>
<div class="form-group row label-capitals">
<label class="col-sm-5 col-form-label"><?php echo $exp_fields_name;?></label>
<div class="col-sm-7">
<input type="<?php echo $exp_fields_type;?>" name="<?php echo $exp_fields_name;?>" placeholder="<?php echo $value;?>" class="form-control" />
<?php echo form_error($exp_fields_name); ?>
</div>
</div>
<?php
}}}?>
我需要像
这样的输出<label>Lastname</label>
<input type="text" name="lastname">
<label>Email</label>
<input type="email" name="email">
你能帮助我吗?
答案 0 :(得分:1)
不是将form_elements存储在fom_builder表中,而是存储它们各自的id,然后使用类似这样的查询
SELECT form_elements_id FROM form_builder
WHERE form_id = 1 AND form_builder_type ='example'ORDER BY update_date DESC LIMIT 1
获得所有表单元素后,Id将其内爆并将其转换为数组,并使用whereIn子句从第二个表中获取数据。