JDBC 中的 ResultSetMetaData 是什麼?它的意義是什麼?
ResultSetMetaData 提供有關獲得的 ResultSet 物件的資訊,例如列數、列名、列的資料型別、表名等。
以下是 ResultSetMetaData 類的部分方法。
方法 | 說明 |
---|---|
getColumnCount() | 檢索當前 ResultSet 物件中的列數。 |
getColumnLabel() | 檢索用於建議使用的列名稱。 |
getColumnName() | 檢索列的名稱。 |
getTableName() | 檢索表的名稱。 |
示例
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.Statement; public class ResultSetMetadataExample { public static void main(String args[]) throws Exception { //Registering the Driver DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //Getting the connection String mysqlUrl = "jdbc:mysql:///TestDB"; Connection con = DriverManager.getConnection(mysqlUrl, "root", "password"); System.out.println("Connection established......"); //Creating a Statement object Statement stmt = con.createStatement(); //Retrieving the data ResultSet rs = stmt.executeQuery("select * from Dataset"); ResultSetMetaData rsMetaData = rs.getMetaData(); //Number of columns System.out.println("Number of columns: "+rsMetaData.getColumnCount()); //Column label System.out.println("Column Label: "+rsMetaData.getColumnLabel(1)); //Column name System.out.println("Column Name: "+rsMetaData.getColumnName(1)); //Number of columns System.out.println("Table Name: "+rsMetaData.getTableName(1)); } }
輸出
Connection established...... Number of columns: 2 Column Label: mobile_brand Column Name: mobile_brand Table Name: dataset
廣告