mysql where后if判断
时间: 2023-07-06 15:04:06 浏览: 46
在MySQL中,可以使用IF函数在WHERE子句中进行条件判断。IF函数接受三个参数,第一个参数是要判断的条件,第二个参数是条件为真时返回的值,第三个参数是条件为假时返回的值。
例如,如果要在表中选择所有年龄大于等于18岁的人,可以使用以下查询:
```
SELECT * FROM persons
WHERE IF(age >= 18, true, false);
```
在这个查询中,IF函数判断年龄是否大于等于18岁,如果是,则返回true,否则返回false。这样,WHERE子句就只选择返回true的记录,即年龄大于等于18岁的人。
相关问题
mysql 触发器进行if 判断
在MySQL触发器中进行if判断可以使用IF语句或者CASE语句来实现。IF语句的基本语法是:
IF condition THEN
statements;
ELSEIF condition THEN
statements;
ELSE
statements;
END IF;
其中,condition是一个条件表达式,statements是一组需要执行的SQL语句。
例如,对于你提供的第一个引用中的触发器内容,可以使用IF语句进行判断:
BEGIN
DECLARE user_name VARCHAR(20);
DECLARE user_age INT;
IF (NEW.name='张三' && OLD.userAge>18) THEN
SELECT name, age INTO user_name, user_age FROM extra_info WHERE user_id = NEW.id;
INSERT into user_form (id,name,age,sex) values (null,user_name,user_age,new.sex);
ELSE
...
END IF;
END;
还可以使用CASE语句进行条件判断,例如:
BEGIN
DECLARE user_name VARCHAR(20);
DECLARE user_age INT;
SET user_name = new.name;
CASE
WHEN (NEW.name='张三' && OLD.age>18) THEN
INSERT into user_form (id,name,age,sex) values (null,user_name,user_age,new.sex);
ELSE
...
END CASE;
END;
请注意,在使用IF语句或者CASE语句时,需要根据具体的逻辑和条件进行编写。
mysql 在where条件中加if
MySQL中可以使用IF函数在WHERE条件中进行条件判断,语法如下:
```
SELECT * FROM table_name WHERE IF(condition, true_value, false_value);
```
其中,condition为条件表达式,true_value为条件成立时的返回值,false_value为条件不成立时的返回值。如果条件成立,则返回true_value,否则返回false_value。
例如,查询表中age大于20岁的记录:
```
SELECT * FROM table_name WHERE IF(age > 20, 1, 0);
```
如果age大于20,则返回1,否则返回0。这样就可以根据条件动态生成WHERE条件,实现更加灵活的查询。