用的mysql4.1的数据库,大概100行10列
有四个列名为name1,name2,name3,name4,都是varchar(30)
有2个字符串变量str1,str2
想要一条sql语句
查出name1,name2,name3,name4中任一个列中含有str1或者str2的所有行的数据
拜托了,最好简单点,谢谢了

解决方案 »

  1.   

    最笨的方法就是用好多or
    可是我想要个简单点的sql语句
      

  2.   

    把name1.....name4都连接到一起,然后再查,这样就用or两次select name1+"###" +name2..... as name form table where  str1 like name or..,
      

  3.   

    SELECT * FROM test where concat(name1,name2,name3,name4) not like '%str1%' or concat(name1,name2,name3,name4) not like '%str2%'
      

  4.   

    谢谢楼上的了,都快忘记用concat了,呵呵