在往mysql中插入记录时怎样获得这条记录的id值
在往mysql中插入记录时怎样获得这条记录的id值
我想要的效果是怎样的在插入记录的时候 有一个字段的值要和id一样
------解决方案--------------------LAST_INSERT_ID()+1
------解决方案--------------------假设$db是你的数据库对象,$sql是你要执行的sql语句。
先执行$db->query($sql);
再执行$last_id = $db->insert_id();
那么$last_id就是你需要的那个ID
------解决方案--------------------
public function insert($data) {
if (!is_array($data)
------解决方案--------------------
empty($data)) return 0;
$data = $this->build_insert($data);
$sql = sprintf("INSERT INTO %s %s", $this->table_name, $data);
$result = $this->query($sql);
return $this->insert_id();
}
------解决方案--------------------当字段id被设置AUTO_INCREMENT自增的时候可以使用一下方式获取:
mysql函数:LAST_INSERT_ID();
php函数:mysql_insert_id();
注:如果字段不是AUTO_INCREMENT的,以上函数将返回0;
------解决方案--------------------插入后,mysql_insert_id() 这个就是插入的id值
------解决方案--------------------mysql_insert_id() 函数返回上一步 insert操作产生的 ID。假如不是自增(AUTO_INCREMENT) 的 ID,那么 mysql_insert_id() 返回 0。
------解决方案--------------------可以是这样的一个思路:
1)先插入主数据,那个和id样值的字段留空;
2)再用$id = mysql_insert_id()获取刚刚插入数据的id;
3)再用update table set 字段={$id}把那个字段更新成和id一样的值
或者先查出目前的最大id,对id加1,再手动插入id和那个和id一样值的字段,设置他们的值等于加1后的id