使用mysqli函数在mysql上插入数据

时间:2015-01-24 17:18:51

标签: php mysql mysqli

如何使用此功能进行插入 我正在学习php,因为使用这个函数(mysqli摘要),但更新后不再工作了。

 /** insert data array */
public function insert(array $arr)
{

    if ($arr)
    {
        $q = $this->make_insert_query($arr);
        $return = $this->modifying_query($q);
        $this->autoreset();
        return $return;
    }
    else
    {
        $this->autoreset();
        return false;
    }
}

补体

  /** insert query constructor */
    protected function make_insert_query($data)
    {
        $this->get_table_info();
        $this->set_field_types();
        if (!is_array(reset($data)))
        {
            $data = array($data);
        }
        $keys = array();
        $values = array();
        $keys_set = false;
        foreach ($data as $data_key => $data_item)
        {
            $values[$data_key] = array();
            $fdata = $this->parse_field_names($data);
            foreach ($fdata as $key => $val)
            {
                if (!$keys_set)
                {
                    if (isset($this->field_type[$key]))
                    {
                        $keys[] = '`' . $val['table'] . '`.`' . $val['field'] . '`';
                    }
                    else
                    {
                        $keys[] = '`' . $val['field'] . '`';
                    }
                }
                $values[$data_key][] = $this->escape($val['value'], $this->is_noquotes($key), $this->field_type($key), $this->is_null($key),
                    $this->is_bit($key));
            }
            $keys_set = true;
            $values[$data_key] = '(' . implode(',', $values[$data_key]) . ')';
        }
        $ignore = $this->ignore ? ' IGNORE' : '';
        $delayed = $this->delayed ? ' DELAYED' : '';
        $query = 'INSERT' . $ignore . $delayed . ' INTO `' . $this->table . '` (' . implode(',', $keys) . ') VALUES ' . implode(',',
            $values);
        return $query;
    }

在更新此类之前,我曾经插入过这样的数据

    $db = Sdba::table('users');
    $data = array('name'=>'adam');
    $db->insert($data);

这种插​​入方法不适用于新类。 如果我这样尝试,我会得到空列和空值。

感谢您的帮助 完整的班级下载http://goo.gl/GK3s4E

1 个答案:

答案 0 :(得分:0)

尝试使用set而不是insert:

$users = Sdba::table('users');

$user['name'] = 'Alvaro';

$users->set($user);