Я отслеживаю все http_user_agents, которые посещают меня, с простым счетчиком. Ниже вставьте http_user_agent в БД, это поле нечувствительно к регистру и является уникальным. Поэтому, когда мы пытаемся вставить его, и он находит DUPLICATE KEY, он добавляет 1 к полю хитов.
Проблема в том, что мое поле Auto Increment все еще увеличивается, даже если мы не вставляем поле. как я могу предотвратить это?
$sql = "INSERT INTO `db_agency_cloud`.`tblRefHttpUsersAgent` SET `http_users_agent` = :UsersAgent, `created_ts` = NOW() ON DUPLICATE KEY UPDATE `hits` = `hits` + 1";
Вот структура таблицы:
CREATE TABLE `tblRefHttpUsersAgent`
(
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`http_users_agent` varchar(255) NOT NULL,
`hits` int(20) unsigned NOT NULL DEFAULT '1',
`created_ts` datetime NOT NULL,
`activity_ts` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`),
UNIQUE KEY `http_users_agent` (`http_users_agent`)
)
ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;