我有一个PHP脚本将新部件插入postgres数据库.我想在创建之前检查零件是否存在.我怎样才能做到这一点.我使用通常的INSERT INTO子句.
你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.请参阅事务隔离.
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)