PHP – 由于违反唯一约束,检测mysql更新/插入失败

这是类似于这个问题:

PHP MySQL INSERT fails due to unique constraint

但我有一个不同的转折.假设我有一张只有一列的表格.列的名称是“title”,它有一个独特的约束.

首先我插入一行title =“something”.下次尝试插入“某物”时,由于唯一的键约束(这是很好的),它将失败.我想做的是允许它失败,并检查MysqL提供的错误代码,以确保它由于唯一的键约束失败. (即让数据库处理唯一性,我只是处理错误代码,并告诉用户结果回来时标题已经存在).

有没有办法做到这一点?

http://dev.mysql.com/doc/refman/5.5/en/error-messages-server.html

http://php.net/manual/en/function.mysql-errno.php

过去我不得不这样做,这不是很有趣:

if( MysqL_errno() == 1062) {
    // Duplicate key
} else {
    // ZOMGFAILURE
}

关于编程风格的注释(从this获取jensgram答案)
您应始终设法避免使用magic numbers.相反,您可以将已知的错误代码(1062)分配给常量(例如MysqL_CODE_DUPLICATE_KEY).这将使您的代码更容易维护,因为if语句中的条件在几个月内仍然可读,当时1062的含义从内存中消失了:)

相关文章

Hessian开源的远程通讯,采用二进制 RPC的协议,基于 HTTP 传输。可以实现PHP调用Java,Python,C#等多语...
初识Mongodb的一些总结,在Mac Os X下真实搭建mongodb环境,以及分享个Mongodb管理工具,学习期间一些总结...
边看边操作,这样才能记得牢,实践是检验真理的唯一标准.光看不练假把式,光练不看傻把式,边看边练真把式....
在php中,结果输出一共有两种方式:echo和print,下面将对两种方式做一个比较。 echo与print的区别: (...
在安装好wampServer后,一直没有使用phpMyAdmin,今天用了一下,phpMyAdmin显示错误:The mbstring exte...
变量是用于存储数据的容器,与代数相似,可以给变量赋予某个确定的值(例如:$x=3)或者是赋予其它的变...