HSQLDB-결과 정렬

SQL SELECT 명령은 레코드를 검색하고 표시하는 동안 특정 순서를 따르는 요구 사항이있을 때마다 HSQLDB 테이블에서 데이터를 가져옵니다. 이 경우 우리는ORDER BY 절.

통사론

다음은 HSQLDB에서 데이터를 정렬하기위한 ORDER BY 절과 함께 SELECT 명령의 구문입니다.

SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
  • 해당 필드가 나열되는 경우 모든 필드에서 반환 된 결과를 정렬 할 수 있습니다.

  • 둘 이상의 필드에서 결과를 정렬 할 수 있습니다.

  • 키워드 ASC 또는 DESC를 사용하여 오름차순 또는 내림차순으로 결과를 얻을 수 있습니다. 기본적으로 오름차순입니다.

  • 일반적인 방법으로 WHERE ... LIKE 절을 사용하여 조건을 입력 할 수 있습니다.

레코드를 가져오고 정렬하는 예를 고려해 보겠습니다. tutorials_tbl저자 이름을 오름차순으로 정렬하여 테이블. 다음은 동일한 쿼리입니다.

SELECT id, title, author from tutorials_tbl ORDER BY author ASC;

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

+------+----------------+-----------------+
| id   |     title      |     author      |
+------+----------------+-----------------+
| 102  |  Learn MySQL   |     Abdul S     | 
| 104  |  Learn JDB     |    Ajith kumar  |
| 103  |  Learn Excell  |    Bavya kanna  |
| 100  |  Learn PHP     |    John Poul    |
| 105  |  Learn Junit   |   Sathya Murthi |
| 101  |  Learn C       |    Yaswanth     |
+------+----------------+-----------------+

HSQLDB – JDBC 프로그램

다음은 레코드를 가져오고 정렬하는 JDBC 프로그램입니다. tutorials_tbl저자 이름을 오름차순으로 정렬하여 테이블. 다음 프로그램을OrderBy.java.

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

public class OrderBy {
   
   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 id, title, author from tutorials_tbl
            ORDER BY author ASC");
         
         while(result.next()){
            System.out.println(result.getInt("id")+" |
            "+result.getString("title")+" |
            "+result.getString("author"));
         }
      } 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 OrderBy.java
\>java OrderBy

위의 명령을 실행하면 다음과 같은 출력이 표시됩니다.

102 | Learn MySQL           | Abdul S
104 | Learn JDB             | Ajith kumar
103 | Learn Excell          | Bavya Kanna
100 | Learn PHP             | John Poul
105 | Learn Junit           | Sathya Murthi
101 | C and Data Structures | Yaswanth