我有一篇包含很多变量的帖子,我想知道是否有某种方法可以动态地将信息插入到 mysql 中,而不是手动全部输入,因为帖子变量会根据用户选择的内容而变化。
这就是我们用来做类似事情的方法(插入到我们无法控制的表中,并且没有 API 访问权限)
使用 DESCRIBE 查询可确保仅插入存在的列。
$db = new DB();
$sql = 'DESCRIBE `table`';
$result = $db->query($sql);
$row = array();
$query = array();
while ($row = $result->fetchRow())
{
if (array_key_exists($row['field'], $form_data))
if (is_null($form_data[$row['field']]))
$query[$row['field']] = 'NULL';
else
$query[$row['field']] = $db->quote($form_data[$row['field']]);
}
$keys = array_keys($query);
foreach ($keys as &$key)
$key = $db->quoteIdentifier($key);
unset($key);
$vals = array_values($query);
$sql = 'INSERT INTO `table` '
. '(' . implode(', ', $keys) . ') '
. 'VALUES(' . implode(', ', $vals) . ')';
编辑:DB() 是我们对 MDB2 的包装。
当然,这允许他们填充整行。如果您有受限列(自动增量 ID 等),则必须从表单数据中过滤掉这些列...
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)