插入前检查是否存在记录

rus*_*nch 3 php postgresql

我有一个PHP脚本将新部件插入postgres数据库.我想在创建之前检查零件是否存在.我怎样才能做到这一点.我使用通常的INSERT INTO子句.

Iva*_*tov 6

SELECT首先要知道如果你必须INSERT或者UPDATE,如:

if (
    $db->fetchOne(
        'SELECT COUNT(1) FROM parts WHERE article_number = ?',
        $p->article_number
    )
) {
    $db->update(
        'parts',
        $p->to_array(),
        $db->quoteInto('article_number = ?', $p->article_number)
    );
}
else {
    $db->insert('parts', $p->to_array());
}
Run Code Online (Sandbox Code Playgroud)

Re Milen的评论:好点!使用默认的PostgreSQL事务隔离级别(READ COMMITTED),可能是另一个进程在您之后插入(并提交)"您的"部分SELECT,但在您之前INSERT.

对于我们构建的应用程序类型,我们通常只捕获数据库异常,并对其执行某些操作(通知用户,重试).或者你可以去SET TRANSACTION ISOLATION LEVEL SERIALIZABLE.请参阅事务隔离.


Mic*_*uen 5

insert into parts(article_number,category) 
select 'KEYB','COMPTR' 
where not exists(select * from parts where article_number = 'KEYB')
Run Code Online (Sandbox Code Playgroud)