Use*_*ser -2 php mysql pdo sql-insert
我需要解决关于失败插入的无效自动增量的问题,以防某些唯一字段重复。
数据库
id : primary key(11) NOT NULL // !important: doesn't have auto increment
field : varchar(25) NOT NULL
Run Code Online (Sandbox Code Playgroud)
询问
$field = 'field1';
try{
$conn = new PDO("....");
$stmt = $conn->prepare("INSERT INTO table (id,field) VALUES (((SELECT MAX(id) FROM table as table_max_id)+1),:field)");
$stmt->bindParam(':field', $field, PDO::PARAM_STR);
if(!$stmt->execute())
print_r($stmt->errorInfo());//Column id cannot be null;
}
...
Run Code Online (Sandbox Code Playgroud)
发现的错误是:
列id不能为空;
如果表中有记录,则仅在表为空时不会发生此验证错误。
我可以通过放置一个带有 fake 的字段来解决问题id = 1,但我真的不喜欢它作为解决方案,有什么想法吗?
用COALESCE别的东西来代替空表达式:
SELECT COALESCE(MAX(id), 0) + 1 FROM table
Run Code Online (Sandbox Code Playgroud)
我建议使用AUTO_NUMBER字段而不是生成 id。