繁体   English   中英

如何在mysql上的插入中在“ SELECT”语句中使用“ IF”

[英]how t use 'IF' in 'SELECT' statement with insert on mysql

我的桌子是

id_stuff | kd_insert | name_stuff | date_createdd 
1        | 1         | example    | 2018-01-01

我这样在mysql中创建查询

SELECT IF ((DATE_FORMAT(NOW(),'%Y-%m') > DATE_FORMAT(MAX(date_createdd),'%Y-%m')), 
(
  INSERT INTO tabless (name_stuff) VALUES ('stuff')
), 
(
 null
)
 ) FROM tabless GROUP BY id_stuff ORDER BY kd_insert

我跑步后为什么会出现这样的错误

错误代码:1064您的SQL语法错误; 查看与您的MySQL服务器版本相对应的手册,以获取在'INTO表(name_stuff)VALUES('stuff')附近使用的正确语法。

以及如何创建select with condition then insert的正确select with condition then insert 谢谢

我认为不可能编写这样的插入语句。 你可以这样做 -

SELECT
  if(
    (DATE_FORMAT(NOW(), '%Y-%m')) > DATE_FORMAT(MAX(date_createdd), '%Y-%m'),
    (@value = 'stuff'),
    null
  )
FROM
  tabless
GROUP BY
  id_stuff
ORDER BY
  kd_insert;
INSERT INTO tabless (name_stuff) VALUES ('stuff');

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM