如何在 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
以下是对示例输出的快照。

广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
安卓
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP