다음은 검색 변수 −
와 함께 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)
insert 명령을 사용하여 일부 레코드를 테이블에 삽입하십시오 -
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)
select 문을 사용하여 테이블의 레코드 표시 -
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://localhost: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
다음은 샘플 출력의 스냅샷입니다.