首页 >Java >java教程 >如何在 MySQL 查询中将 LIKE 通配符与预准备语句一起使用?

如何在 MySQL 查询中将 LIKE 通配符与预准备语句一起使用?

Patricia Arquette
Patricia Arquette原创
2024-11-15 09:11:03885浏览

How to Use LIKE Wildcard with Prepared Statements in MySQL Queries?

在 MySQL 查询中将 LIKE 通配符与准备好的语句结合使用

在 MySQL 数据库查询中,LIKE 运算符允许基于模式的搜索。当使用预备语句执行此类查询时,正确合并 LIKE 通配符至关重要。

一个常见的要求是执行前缀匹配搜索。为此,应将关键字% 附加到搜索词后。但是,在使用预准备语句时,将通配符直接连接到参数值是不正确的。

相反,应在预准备语句查询中设置值本身。对于前缀匹配,请按如下方式修改搜索词:

notes = notes
    .replace("!", "!!")
    .replace("%", "!%")
    .replace("_", "!_")
    .replace("[", "![");

PreparedStatement pstmt = con.prepareStatement(
        "SELECT * FROM analysis WHERE notes LIKE ? ESCAPE '!'");
pstmt.setString(1, notes + "%");

ESCAPE 关键字表示用于转义通配符内特殊字符的转义字符。默认情况下,它是反斜杠 (),但可以更改为任何字符。

类似地,对于后缀匹配,请使用以下内容:

pstmt.setString(1, "%" + notes);

对于全局match:

pstmt.setString(1, "%" + notes + "%");

通过在搜索项中设置通配符,LIKE 运算符可以有效地与准备好的语句一起使用来执行各种操作MySQL 数据库中基于模式的搜索。

以上是如何在 MySQL 查询中将 LIKE 通配符与预准备语句一起使用?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn