1. 程式人生 > >[瘋狂Java]JDBC:ResultSetMetaData(結果集元資料分析)

[瘋狂Java]JDBC:ResultSetMetaData(結果集元資料分析)

1. 描述ResultSet資訊的資料——ResultSetMetaData:

    1) MetaData即元資料,即描述其它資料的資料,因此ResultSetMetaData就是描述ResultSet的元資料;

    2) 通常在你對查詢結果不瞭解的情況下可以使用該元資料來了解結果集的記錄有幾列,每列的型別是啥,每列的名稱是啥?

2. 分析ResultSet元資料:

    1) 首先你要獲得ResultSetMetaData物件(必定是從屬於某個ResultSet物件):ResultSetMetaData ResultSet.getMetaData();

    2) 元資料物件中最常用的三種方法來獲取記錄的有關資訊:都是ResultSetMetaData的物件方法

         i. int getColumnCount(); // 獲取列數

         ii. String getColumnName(int column);  // 獲取指定列的列名,列索引從1開始計

         iii. int getColumnType(int column);  // 獲取指定列的SQL型別,是Types中定義的靜態常量

    3) 一般不推薦使用ResultSetMetaData來分析結果集,因為這樣分析需要一定的系統開銷(底層查詢資料庫中的元資料然後返回想要的值),因此最好是先了解資料表的具體結構然後直接分析結果集比較好;

    4) 示例:完全依賴ResultSetMetaData來解析結果集

public class Test {
	
	private Connection conn;
	private Statement stmt;
	
	private JFrame jf;
		private JPanel jp;
			private JLabel jl;
			private JTextField jt;
			private JButton jb;
		private JScrollPane jscp; // 顯示查詢結果的滾動面板
	
	class ExecListener implements ActionListener {

		@Override
		public void actionPerformed(ActionEvent e) {
			// TODO Auto-generated method stub
			if (jscp != null) {
				jf.remove(jscp); // 先刪掉原有的結果列表面板
			}
			
			try (
				ResultSet rs = stmt.executeQuery(jt.getText())
			) {
				ResultSetMetaData rsmd = rs.getMetaData();
				Vector<String> colNames = new Vector<>(); // 列名
				Vector<Vector<String>> rows = new Vector<>(); // 行的集合
				
				for (int i = 0; i < rsmd.getColumnCount(); i++) { // 獲取列名
					colNames.add(rsmd.getColumnName(i + 1));
				}
				while (rs.next()) {
					Vector<String> v = new Vector<>();
					for (int i = 0; i < rsmd.getColumnCount(); i++) { // 填寫rows
						v.add(rs.getString(i + 1));
					}
					rows.add(v);
				}
				
				JTable jtable = new JTable(rows, colNames); // 利用rows和colNames建立一個列表控制元件
				jscp = new JScrollPane(jtable);
				jf.add(jscp);
				jf.validate(); // 主介面重畫一遍
			}
			catch (Exception ex) {
				ex.printStackTrace();
				return ;
			}
		}
		
	}
	
	public void init() {
		try { // 準備連線並獲取控制代碼
			Properties props = new Properties();
			props.load(new FileInputStream("mysql.ini"));
			String driver = props.getProperty("driver");
			String url = props.getProperty("url");
			String user = props.getProperty("user");
			String pass = props.getProperty("pass");
			
			conn = DriverManager.getConnection(url, user, pass);
			stmt = conn.createStatement();
		}
		catch (Exception e) {
			e.printStackTrace();
		}
		
		// 載入主介面
		jf = new JFrame("SQL查詢器");
			jp = new JPanel(); jf.add(jp, BorderLayout.NORTH);
				jl = new JLabel("輸入查詢語句:"); jp.add(jl);
				jt = new JTextField(45); jp.add(jt);
				jb = new JButton("查詢"); jp.add(jb);
				
		jt.addActionListener(new ExecListener());
		jb.addActionListener(new ExecListener());
		
		jf.setSize(700, 480);
		jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		jf.setVisible(true);
	}

	public static void main(String[] args) {
		new Test().init();
	}

}