如何在 Java 中使用 MySQL 的 LIKE 与搜索变量同时使用引号?


以下是如何正确使用 LIKE 与搜索变量的语法 −

String sqlQuery;
sqlQuery = "select *from yourTableName where yourColumnName like '%" +yourSearchVariableName + "%'";

让我们创建一个表 −

mysql> create table demo19
−> (
−> id int not null auto_increment primary key,
−> name varchar(50)
−> );
Query OK, 0 rows affected (3.48 sec)

在表中插入一些记录,使用插入命令 −

mysql> insert into demo19(name) values('John Smith');
Query OK, 1 row affected (0.15 sec)

mysql> insert into demo19(name) values('David Miller');
Query OK, 1 row affected (0.15 sec)

mysql> insert into demo19(name) values('Adam Smith');
Query OK, 1 row affected (0.12 sec)

mysql> insert into demo19(name) values('Chris Brown');
Query OK, 1 row affected (0.13 sec)

使用选择语句显示表中的记录 −

mysql> select *from demo19

这将产生以下输出 −

+----+--------------+
| id | name         |
+----+--------------+
|  1 | John Smith   |
|  2 | David Miller |
|  3 | Adam Smith   |
|  4 | Chris Brown  |
+----+--------------+
4 rows in set (0.00 sec)

示例

以下是如何在使用 LIKE 与搜索变量的同时正确使用引号的 Java 代码 −

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class RemoveJavaQueryError {
   public static void main(String[] args) {
      Connection con = null;
      Statement statement = null;
      try {
         String searchKeyWord = "Smith";
         Class.forName("com.mysql.jdbc.Driver");
         con = DriverManager.getConnection("jdbc:mysql://:3306/sampledatabase", "root", "123456");
         statement = (Statement) con.createStatement();
         String sqlQuery;
         sqlQuery = "select *from demo19 where name like '%" + searchKeyWord + "%'";
         ResultSet rs = statement.executeQuery(sqlQuery);
         while (rs.next()) {
            System.out.println(rs.getString("name"));
         }
      } catch (Exception e) {
         e.printStackTrace();
      }
   }
}

这将产生以下输出 −

John Smith
Adam Smith

以下是对示例输出的快照。

更新于: 19-11-2020

543 次浏览

开启您的职业生涯生涯

完成课程并拿到认证

开始学习
广告
© . All rights reserved.