areming 发表于 2009-9-1 15:06:00

帮我看看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:59

快帮帮我吧,谢谢大家了,在线等

uknow 发表于 2009-9-18 16:38:31

这些输入,应该交给具体的程序比如php去做效率更高吧
页: [1]
查看完整版本: 帮我看看MYSQL里的IF语句