Я отслеживаю все http_user_agents, которые посещают меня, с помощью простого счетчика посещений.
Ниже вставляется http_user_agent в БД, это поле не чувствительно к регистру и уникально. Поэтому, когда мы пытаемся вставить его и он находит ДУБЛИКАТНЫЙ КЛЮЧ, он добавляет 1 к полю хитов.
Проблема в том, что мое поле автоматического увеличения все еще увеличивается, хотя мы не вставляли поле. как я могу предотвратить это?
$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;