Обновить запись в таблице, если она существует (с предложением), или создать ее, если нет

Я пытаюсь написать запрос, который обновит запись, если она существует, или создаст ее, если ее нет, тем не мение Я хочу сделать это на основе условия, что text_value еще не установлен.

Я изначально думал об использовании REPLACE, но это не поддерживает WHERE пункт.

REPLACE INTO settings
SET var_name = '',
var_group = '',
text_value = '',
country_id = ''

Могу ли я сделать то, что я хочу сделать в одном запросе? Я пытаюсь сделать это без необходимости писать что-то вроде этого, где у меня есть два запроса в моем PHP:

SELECT FROM settings WHERE text_value != '' AND country_id = $country_id

Если это не дает результатов, то

INSERT INTO settings...

Это моя таблица DDL информации:

CREATE TABLE `settings` (
`settings_id` int(11) NOT NULL auto_increment,
`var_name` varchar(50) default NULL,
`var_group` varchar(26) NOT NULL,
`text_value` text NOT NULL,
`country_id` int(11) NOT NULL,
PRIMARY KEY  (`settings_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

0

Решение

Задача ещё не решена.

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]