SELECT MAX(id) 在空表中返回 NULL 而不是 0

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,但我真的不喜欢它作为解决方案,有什么想法吗?

Sal*_*n A 5

COALESCE别的东西来代替空表达式:

SELECT COALESCE(MAX(id), 0) + 1 FROM table
Run Code Online (Sandbox Code Playgroud)

我建议使用AUTO_NUMBER字段而不是生成 id。