【问题标题】:serialize - using serialize() to pass values into databaseserialize - 使用 serialize() 将值传递到数据库
【发布时间】:2016-09-14 10:22:16
【问题描述】:

我有这段代码(在调查表中)

<div  id="change-color0">
    <label><span class="turn-white0">01</span>Họ tên đầy đủ của bạn</label>
    <input type="text" id="input" name="content[]" class="addtodo0">
</div>
<div id="change-color1">
    <label><span class="turn-white1">02</span>Số chứng minh thư nhân dân của bạn</label>
    <input type="text" id="input" name="content[]" class="addtodo1">                   
</div>
<div id="change-color2">
    <label><span class="turn-white2">03</span>Địa chỉ thường trú của bạn</label>
    <input type="text" id="input" name="content[]" class="addtodo2">
</div>
<div id="change-color3">
    <label><span class="turn-white3">04</span>Tại sao bạn muốn trở thành học viên của dự án</label>
    <input type="text" id="input" name="content[]" class="addtodo3">
</div>
<div id="change-color4">
    <label><span class="turn-white4">05</span>Bạn nghĩ mình là ai</label>
    <input type="text" id="input" name="content[]" class="addtodo4">
</div>
<div id="change-color5">
    <label><span class="turn-white5">06</span>Trong mắt người khác bạn là ai</label>
    <input type="text" id="input" name="content[]" class="addtodo5">
</div>
<div id="change-color6">
    <label><span class="turn-white6">07</span>Bạn sợ nhất điều gì</label>
    <input type="text" id="input" name="content[]" class="addtodo6">
</div>
<div id="change-color7">
    <label><span class="turn-white7">08</span>Ước mơ của bạn là gì?</label>
    <input type="text" id="input" name="content[]" class="addtodo7">
</div>
<div id="change-color8">
    <label><span class="turn-white8">09</span>10 năm nữa bạn là ai?</label>
    <input type="text" id="input" name="content[]" class="addtodo8">
</div>

我想通过使用序列化和反序列化在我的数据库的一行中输入这些文本字段。 另外,有很多表单,包括代码中的那些文本字段,所以我如何给他们一个身份来执行 MYSQL 查询,然后我可以调用我想要的那个。

即。我希望显示每个表单的第一个输入。我该怎么做 那个?

【问题讨论】:

  • 最好用键值对和 FK imo 将所有这些分隔到另一个表中。
  • 这不是我的意思,兄弟。 Thoes 字段采用调查表。一个表单属于一个用户(我为用户表添加了 fk)。

标签: php sql serialization


【解决方案1】:

实际上你不应该使用serialize(),因为当你从 SQL 中调出信息时,你不能准确地调用你想要的那个。

您最好使用implode(),而不是使用serialize(),将您的值保存到数据库的一行中。 使用您的代码 sn-p,我建议您应该替换

name="内容"

使用特定名称。这段代码应该适用于您的情况

$arry = array("$_POST[name]","$_POST[name]","$_POST[name]");
$insert = implode(",",$array);
$sql = $conn->query("INSERT INTO yourtable_name VALUES('$insert')");
if($query){
echo "insertion grand!";
}else{
die();

}

【讨论】:

  • 1) Implode 只是稍微好一点,你应该规范化你的数据存储。 2) 此代码易受 SQL 注入攻击。
猜你喜欢
  • 2011-11-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多