HSQLDB-LIKE 절

RDBMS 구조에 WHERE 절이 있습니다. 정확히 일치하려는 위치에 등호 (=)와 함께 WHERE 절을 사용할 수 있습니다. 그러나 저자 이름에 "john"이 포함되어야하는 모든 결과를 필터링하려는 요구 사항이있을 수 있습니다. 이것은 WHERE 절과 함께 SQL LIKE 절을 사용하여 처리 할 수 ​​있습니다.

SQL LIKE 절이 % 문자와 함께 사용되는 경우 UNIX에서는 명령 프롬프트에서 모든 파일 또는 디렉토리를 나열하는 동안 메타 문자 (*)처럼 작동합니다.

통사론

다음은 LIKE 절의 일반 SQL 구문입니다.

SELECT field1, field2,...fieldN table_name1, table_name2...
WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
  • WHERE 절을 사용하여 모든 조건을 지정할 수 있습니다.

  • LIKE 절을 WHERE 절과 함께 사용할 수 있습니다.

  • 등호 기호 대신 LIKE 절을 사용할 수 있습니다.

  • LIKE 절이 % 기호와 함께 사용되면 메타 문자 검색처럼 작동합니다.

  • AND 또는 OR 연산자를 사용하여 둘 이상의 조건을 지정할 수 있습니다.

  • WHERE ... LIKE 절을 DELETE 또는 UPDATE SQL 명령과 함께 사용하여 조건을 지정할 수 있습니다.

작성자 이름이 다음으로 시작하는 튜토리얼 데이터 목록을 검색하는 예를 고려해 보겠습니다. John. 다음은 주어진 예에 대한 HSQLDB 쿼리입니다.

SELECT * from tutorials_tbl WHERE author LIKE 'John%';

위 쿼리를 실행하면 다음과 같은 출력이 표시됩니다.

+-----+----------------+-----------+-----------------+
|  id |      title     |   author  | submission_date |
+-----+----------------+-----------+-----------------+
| 100 |    Learn PHP   | John Poul | 2016-06-20      |
+-----+----------------+-----------+-----------------+

HSQLDB – JDBC 프로그램

다음은 작성자 이름이 다음으로 시작하는 튜토리얼 데이터 목록을 검색하는 JDBC 프로그램입니다. John. 코드 저장LikeClause.java.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class LikeClause {
   
   public static void main(String[] args) {
      Connection con = null;
      Statement stmt = null;
      ResultSet result = null;
      
      try {
         Class.forName("org.hsqldb.jdbc.JDBCDriver");
         con = DriverManager.getConnection(
            "jdbc:hsqldb:hsql://localhost/testdb", "SA", "");
         stmt = con.createStatement();
         result = stmt.executeQuery(
            "SELECT * from tutorials_tbl WHERE author LIKE 'John%';");
         
         while(result.next()){
            System.out.println(result.getInt("id")+" |
               "+result.getString("title")+" |
               "+result.getString("author")+" |
               "+result.getDate("submission_date"));
         }
      } catch (Exception e) {
         e.printStackTrace(System.out);
      }
   }
}

다음 명령을 사용하여 데이터베이스를 시작할 수 있습니다.

\>cd C:\hsqldb-2.3.4\hsqldb
hsqldb>java -classpath lib/hsqldb.jar org.hsqldb.server.Server --database.0
file:hsqldb/demodb --dbname.0 testdb

다음 명령을 사용하여 위 코드를 컴파일하고 실행합니다.

\>javac LikeClause.java
\>java LikeClause

다음 명령을 실행하면 다음 출력이 표시됩니다.

100 | Learn PHP | John Poul | 2016-06-20