MariaDB社区

标题: 帮我看看MYSQL里的IF语句 [打印本页]

作者: areming    时间: 2009-9-1 15:06
标题: 帮我看看MYSQL里的IF语句
本帖最后由 areming 于 2009-9-1 15:33 编辑

想在MYSQL里做一个判断查询
学生姓名表 T
学生详细信息表 S
条件 姓名,年龄,姓别,入学时间
功能:先判断是否输入了姓名
是就执行:1
不是就判断是否输入了年龄,是就执行:2
不是就判断是否输入了姓别,是就执行:3
不是就判断是否输入了入学时间,是就执行:4
都没填就全部查询
我写的语句如下
select * from s
where
if(T.姓名!=null)
{
//1
   select * from s where s.姓名 in(select 姓名 from T where T.姓名=姓名)
}
else
{
   if(S.年龄!=null)
   {
//2
select * from s where S.年龄=年龄
   }
   else
   {
if(S.姓别!=null)
{
  //3
    select * from s where S.姓别=姓别
}
else
{
    if(S.入学时间!=null)
    {
   //4
  select * from s where S.入学时间=入学时间
    }
    else
    {
   //5
     select * from s where s.姓名 in(select 姓名 from T where T)
           }
}
   }
}
作者: areming    时间: 2009-9-1 15:07
快帮帮我吧,谢谢大家了,在线等
作者: uknow    时间: 2009-9-18 16:38
这些输入,应该交给具体的程序比如php去做效率更高吧




欢迎光临 MariaDB社区 (http://123.56.88.72/) Powered by Discuz! X3.2