MySQL存储过程:搜索数量可变的字符串 - java

我需要一个称为的存储过程:

search('foo bar')

进行类似于以下的搜索:

SELECT FROM A, B
WHERE A.B_ID = B.ID
AND (A.f1 LIKE '%foo%' OR A.f2 LIKE '%foo%' OR B.f3 LIKE '%foo%')
AND (A.f1 LIKE '%bar%' OR A.f2 LIKE '%bar%' OR B.f3 LIKE '%bar%')

我有一些疑问和疑问:

  • 我无法将数组传递给过程,所以我唯一的选择是像示例中那样直接传递字符串('foo bar')?
  • 因此,我假设我必须在SP代码中进行拆分。我不知道怎么做,所以我搜索并找到了this solution。使用临时表以及我认为很多笨拙的代码。真的那么复杂吗?性能如何?
  • 我不知道如何创建这样的动态查询。我想我必须遍历 token 以为每个人创建WHERE子句的新块,但是我不确定如何执行此操作或它是否是最佳解决方案。也许连接字符串然后编写准备好的语句会更好?
  • 谢谢。

    注意:我使用iBATIS(Java)来调用此例程。

    参考方案

    您想要使用的是全文搜索(FTS)-MySQL的本机FTS功能只能在MyISAM表和Sphinx等第三方FTS上使用。这是an online slideshow that's a decent intro & howto。

    使用MySQL本机FTS,您的查询将类似于:

    SELECT *
      FROM A AS a
      JOIN B AS b ON b.id = a.b_id
     WHERE MATCH (a.f1, a.f2, b.f3) AGAINST ('foo bar');
    

    仍然可以选择动态SQL,具体取决于您希望/需要进行查询的强度。在考虑动态SQL之前,我会先研究FTS产品。

    Java-如何将此字符串转换为日期? - java

    我从服务器收到此消息,我不明白T和Z的含义,2012-08-24T09:59:59Z将此字符串转换为Date对象的正确SimpleDateFormat模式是什么? java大神给出的解决方案 这是ISO 8601标准。您可以使用SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM…

    Java:正则表达式模式匹配器是否有大小限制? - java

    我的模式类似于OR:“word1 | word2 | word3”我大约有800个字。可能有问题吗? 参考方案 您仅受记忆和理智的限制。 :)

    Java:线程池如何将线程映射到可运行对象 - java

    试图绕过Java并发问题,并且很难理解线程池,线程以及它们正在执行的可运行“任务”之间的关系。如果我创建一个有10个线程的线程池,那么我是否必须将相同的任务传递给池中的每个线程,或者池化的线程实际上只是与任务无关的“工人无人机”可用于执行任何任务?无论哪种方式,Executor / ExecutorService如何将正确的任务分配给正确的线程? 参考方案 …

    JAVA:字节码和二进制有什么区别? - java

    java字节代码(已编译的语言,也称为目标代码)与机器代码(当前计算机的本机代码)之间有什么区别?我读过一些书,他们将字节码称为二进制指令,但我不知道为什么。 参考方案 字节码是独立于平台的,在Windows中运行的编译器编译的字节码仍将在linux / unix / mac中运行。机器代码是特定于平台的,如果在Windows x86中编译,则它将仅在Win…

    java:继承 - java

    有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…