duanshan5259 2015-05-21 16:59
浏览 37

更新表中的记录(如果存在)(带子句)或如果不存在则创建它

I am attempting to write a query that will update the record if it exists, or create it if it does not, however I want to do that based on the condition that text_value is not already set.

I initally thought of using REPLACE, but that does not support a WHERE clause.

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

Can I do what I want to do in one query? I am trying to do so without having to write something like this where I have two queries in my PHP:

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

IF that returns no results then

INSERT INTO settings...

This is my table DDL information:

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条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 求帮我调试一下freefem代码
    • ¥15 R语言Rstudio突然无法启动
    • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
    • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
    • ¥15 用windows做服务的同志有吗
    • ¥60 求一个简单的网页(标签-安全|关键词-上传)
    • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
    • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
    • ¥100 为什么这个恒流源电路不能恒流?
    • ¥15 有偿求跨组件数据流路径图