亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? databasetest1.java.bak

?? Java程序設(shè)計培訓(xùn)教程2
?? BAK
字號:
import javax.swing.*;
import java.awt.*;
import javax.swing.table.*;
import java.applet.Applet;
import java.sql.*;
import java.awt.event.*;
import java.util.Vector;

/**類DatabaseTest1類的目的是取得數(shù)據(jù)庫中的信息以表格的形式顯示出來*/
public class DatabaseTest1{
	public static void main(String args[]){
	/*聲明一個JFrame對象,標(biāo)題為"FancyTable"*/
    JFrame frame=new JFrame("An example of database!");
    /*聲明一個JLabel對象,用于放在JFrame正上方*/
    JLabel titleLabel=new JLabel("Talbe demo!");
    
	/*聲明了兩個JPanel對象,mainPanel用于放置顯示數(shù)據(jù)所用的表格,subPanel用于放置上面的sortButton和queryButton兩個按鈕*/
    JPanel mainPanel=new JPanel(false);
     
    /*聲明一個JScrollPane對象tablePanel,用于使得生成的表格帶有滾動條*/
    JScrollPane tablePanel;
     /*調(diào)用本類中的createTable()方法生成表格*/
    tablePanel=createTable();
    mainPanel.add(tablePanel);
	/*為Frame對象注冊窗口事件監(jiān)聽器,這樣就可以單擊界面右上方的關(guān)閉按鈕退出程序的運行*/
    frame.addWindowListener(new WindowAdapter(){
        public void windowClosing(WindowEvent e){System.exit(0);}});
    /*將mainPanel添加到Frame中的Center位置*/
    frame.getContentPane().add("Center",mainPanel);

    /*使Frame以最緊湊的樣式顯示*/
    frame.pack();
    /*使Frame可見*/
    frame.setVisible(true);
    }
	/**createTable() creates a table and add the table to a JScrollPane,then return the JScrollPane*/
    public static JScrollPane createTable(){
        TableModel stuTable;
        JDBCAdapter dt;
        /*聲明Vector型變量rowVector,用于存放讀取到的信息*/
   		Vector rowVector;
   		/*聲明JTable對象,用于會創(chuàng)建一個顯示讀取信息的表格*/
    	JTable table;

    	/*通過JDBC訪問數(shù)據(jù)庫獲得的數(shù)據(jù)創(chuàng)建表格*/
    	/*url指定需要訪問的數(shù)據(jù)庫名稱*/
        String url="jdbc:odbc:MyDatabase";
        /*driver指定訪問數(shù)據(jù)庫的驅(qū)動程序的名稱*/
        String driver="sun.jdbc.odbc.JdbcOdbcDriver";
        /*user和password用于指定訪問數(shù)據(jù)庫時使用的用戶名和密碼*/
        String user="sa";
        String password="";
        /*query代表需要執(zhí)行的SQL語句*/
        String query="select * from student1";
        /*通過構(gòu)造一個JDBCAdapter類的對象來訪問數(shù)據(jù)庫*/
        dt=new JDBCAdapter(url,driver,user,password);
		/*對指定的數(shù)據(jù)庫MyDatabase執(zhí)行SQL語句,executeQuery方法是類JDBCAdapter中定義的*/
        dt.executeQuery(query);
        /*將取得的結(jié)果賦給stuTable對象*/
        stuTable=dt;
        /*根據(jù)取得的數(shù)據(jù)創(chuàng)建表格*/
        table=new JTable(stuTable);
        /*用矢量rowVector存放取得的數(shù)據(jù)行向量*/
        rowVector=dt.rows;
        
        /*使得表格各列的大小設(shè)置為可以自動調(diào)節(jié)*/
        table.setAutoResizeMode(JTable.AUTO_RESIZE_ALL_COLUMNS);
        /*根據(jù)創(chuàng)建的表格生成JScrollPane對象,這樣表格就可以帶有滾動條*/
        JScrollPane scrollpane=new JScrollPane(table);
        return scrollpane;
    }
}

/**類JDBCAdapter是AbstractTableModel的子類*/
class JDBCAdapter extends AbstractTableModel {
    /*聲明一個Connection對象,用于和數(shù)據(jù)庫建立連接*/
    Connection          connection;
    /*聲明一個Statement對象,用于對數(shù)據(jù)庫執(zhí)行SQL語句*/
    Statement           statement;
    /*聲明一個ResultSet對象,用于存放SQL語句執(zhí)行的結(jié)果*/
    ResultSet           resultSet;
    /*定義一個字符串?dāng)?shù)組,用于存放結(jié)果集中的列數(shù)*/
    String[]            columnNames = {};
    /*聲明一個Vector對象,用于將取得的數(shù)據(jù)按行放在rows中*/
    Vector		rows = new Vector();
    /*聲明ResultSetMetaData對象,用于從ResultSet對象中獲得數(shù)據(jù)屬性和類型*/
    ResultSetMetaData   metaData;
    /**下面是構(gòu)造方法,四個參數(shù)分別代表要連接的數(shù)據(jù)庫,驅(qū)動程序,用戶名和密碼*/
    public JDBCAdapter(String url, String driverName,
                       String user, String passwd) {
        try {
        	/*返回driverName字符串對應(yīng)的類對象*/
            Class.forName(driverName);
            /*輸出"Opening db connection"提示信息*/
            System.out.println("Opening db connection");
			/*下面的語句進(jìn)行數(shù)據(jù)庫的連接*/
            connection = DriverManager.getConnection(url, user, passwd);
            /*創(chuàng)建SQL語句*/
            statement = connection.createStatement();
        }
        catch (ClassNotFoundException ex) {
            /*輸出沒有找到數(shù)據(jù)庫驅(qū)動程序類的信息*/
            System.err.println("Cannot find the database driver classes.");
            System.err.println(ex);
        }
        catch (SQLException ex) {
        	/*輸出不能連接到數(shù)據(jù)庫的信息*/
            System.err.println("Cannot connect to this database.");
            System.err.println(ex);
        }
     }
    /**executeQuery(String query)方法執(zhí)行字符串參數(shù)query指定的語句*/
    public void executeQuery(String query) {
    	/*if語句中的條件表示數(shù)據(jù)庫連接不成功或者沒有創(chuàng)建SQL語句*/
        if (connection == null || statement == null) {
            System.err.println("There is no database to execute the query.");
            return;
        }
        try {
        	/*執(zhí)行SQL語句,將結(jié)果放在結(jié)果集對象resultSet中*/
            resultSet = statement.executeQuery(query);
			/*通過getMetaData()方法將resultSet中的數(shù)據(jù)傳到ResultSetMetaData對象metaData中*/
            metaData = resultSet.getMetaData();
            /*獲得metaData中數(shù)據(jù)的列數(shù)*/
            int numberOfColumns =  metaData.getColumnCount();
            /*根據(jù)取得的列數(shù)創(chuàng)建字符串?dāng)?shù)組,數(shù)組的長度就是上面得到的列數(shù)*/
            columnNames = new String[numberOfColumns];
            /*將取得數(shù)據(jù)的各列名稱賦給字符串?dāng)?shù)組中的各元素*/
            for(int column = 0; column < numberOfColumns; column++) {
                columnNames[column] = metaData.getColumnLabel(column+1);
            }
            /*對rows進(jìn)行初始化*/
            rows = new Vector();
            while (resultSet.next()) {
            	/*聲明一個Vector對象newRow,用于存放取得結(jié)果集中一行數(shù)據(jù)*/
                Vector newRow = new Vector();
                /*利用一個for循環(huán),將結(jié)果集中一行數(shù)據(jù)放到newRow矢量中*/
                for (int i = 1; i <= getColumnCount(); i++) {
	            newRow.addElement(resultSet.getObject(i));
            	}
				/*將上面的矢量newRow作為矢量rows中的一個元素,這樣rows中的一個元素就代表結(jié)果集中的一行數(shù)據(jù)*/
                rows.addElement(newRow);
            }
            /*將發(fā)生的事件提交給監(jiān)聽器*/
            fireTableChanged(null); // Tell the listeners a new table has arrived.
        }
        catch (SQLException ex) {
            System.err.println(ex);
        }
    }
    /**將前面生成的結(jié)果集對象、SQL語句對象和數(shù)據(jù)庫連接對象關(guān)閉*/
    public void close() throws SQLException {
        System.out.println("Closing db connection");
        resultSet.close();
        statement.close();
        connection.close();
    }
    /**通過finalize()執(zhí)行上面的close()方法*/
    protected void finalize() throws Throwable {
        close();
        super.finalize();
    }
	/**
     * Implementation of the TableModel Interface
     */
    /*重寫getColumnName方法,獲得參數(shù)column指定列的名稱*/
    public String getColumnName(int column) {
        if (columnNames[column] != null) {
            return columnNames[column];
        } else {
            return "";
        }
    }
    /*值得注意的是,實現(xiàn)TabelModel接口,必須重寫下面三個方法*/
    /**重寫getColumnCount方法,獲得列數(shù)*/
    public int getColumnCount() {
        return columnNames.length;
    }
	/**重寫getRowCount方法,獲得行數(shù)*/
    public int getRowCount() {
        return rows.size();
    }
	/**重寫getValueAt方法,獲得參數(shù)指定位置的對象*/
    public Object getValueAt(int aRow, int aColumn) {
        Vector row = (Vector)rows.elementAt(aRow);
        return row.elementAt(aColumn);
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品一二三区| 亚洲自拍都市欧美小说| 男人操女人的视频在线观看欧美| 欧美亚洲综合网| 午夜精品久久一牛影视| 91超碰这里只有精品国产| 亚洲成a人在线观看| 日韩欧美亚洲国产另类| 国产一区二区在线视频| 国产女人18毛片水真多成人如厕| 成人黄色777网| 一区二区三区中文字幕电影 | 日韩精品福利网| 欧美一区二区三区在线看| 激情综合网最新| 国产精品毛片大码女人| 在线亚洲一区观看| 日韩黄色免费电影| 国产婷婷色一区二区三区在线| 成人av资源下载| 亚洲国产精品一区二区www| 日韩一卡二卡三卡国产欧美| 国产精品正在播放| 亚洲男女一区二区三区| 国产性做久久久久久| 色美美综合视频| 免费人成黄页网站在线一区二区 | 99国产精品99久久久久久| 亚洲一区欧美一区| www日韩大片| 91极品美女在线| 美国十次了思思久久精品导航| 国产精品人妖ts系列视频| 欧美性视频一区二区三区| 精品中文字幕一区二区小辣椒| 国产精品网站导航| 欧美精品精品一区| 成人av影院在线| 麻豆91在线播放| 亚洲精品一二三四区| 精品成人私密视频| 欧美亚洲一区二区在线| 成人毛片老司机大片| 麻豆freexxxx性91精品| 一区二区三区免费| 欧美国产丝袜视频| 91精品国产综合久久福利| 99在线精品一区二区三区| 另类欧美日韩国产在线| 一区二区三区在线播放| 国产亚洲精品超碰| 日韩精品一区二区三区老鸭窝 | 亚洲女爱视频在线| 久久久不卡网国产精品一区| 欧美日韩亚洲综合在线 | 欧美大片在线观看| 欧美亚洲日本国产| www.一区二区| 国产激情视频一区二区三区欧美 | 成人97人人超碰人人99| 蜜臀精品久久久久久蜜臀| 亚洲一区二三区| 中文字幕一区二区三| 久久看人人爽人人| 日韩精品在线网站| 欧美精品v日韩精品v韩国精品v| jizz一区二区| 高清av一区二区| 国产精品一区在线观看乱码| 另类小说色综合网站| 日韩精品亚洲一区| 亚瑟在线精品视频| 亚洲v精品v日韩v欧美v专区| 一区二区三区高清在线| 亚洲精品亚洲人成人网| 亚洲丝袜美腿综合| 中文字幕亚洲一区二区va在线| 国产欧美日本一区二区三区| 2020国产成人综合网| 亚洲精品一区二区三区福利| 精品免费99久久| 久久综合狠狠综合久久激情| 欧美r级在线观看| 久久一日本道色综合| 精品国精品国产尤物美女| 欧美精品一区男女天堂| 热久久国产精品| 舔着乳尖日韩一区| 蜜桃视频第一区免费观看| 青娱乐精品视频在线| 久久精品国产一区二区三| 裸体在线国模精品偷拍| 国产精品自拍毛片| 成人app网站| 在线精品视频一区二区三四| 欧美日韩国产片| 在线不卡一区二区| ww亚洲ww在线观看国产| 中文字幕不卡一区| 亚洲最大成人综合| 日韩av一区二区三区| 国模大尺度一区二区三区| 国产激情精品久久久第一区二区| 国产成人超碰人人澡人人澡| 成人免费毛片app| 91行情网站电视在线观看高清版| 色哟哟日韩精品| 3d成人h动漫网站入口| 久久在线免费观看| 18成人在线观看| 亚洲国产综合色| 久久精品二区亚洲w码| 成人午夜电影小说| 在线观看av一区| 日韩欧美不卡一区| 中文字幕中文乱码欧美一区二区| 亚洲一区自拍偷拍| 国产在线乱码一区二区三区| 色综合天天性综合| 欧美一个色资源| 国产精品色噜噜| 日本aⅴ精品一区二区三区| 成人免费看视频| 欧美精品亚洲二区| 国产精品萝li| 七七婷婷婷婷精品国产| 成人精品电影在线观看| 777午夜精品免费视频| 亚洲国产经典视频| 日韩在线a电影| www.在线成人| 精品999在线播放| 亚洲午夜三级在线| 成人av在线一区二区| 欧美一区二区三区喷汁尤物| 亚洲欧美一区二区视频| 国产一区二区不卡在线| 欧美日韩亚洲丝袜制服| 中文字幕一区二区三区蜜月| 久久精品国产**网站演员| 在线视频欧美精品| 国产精品免费看片| 国内精品国产成人| 欧美精品三级在线观看| 成人欧美一区二区三区视频网页| 狠狠色狠狠色综合日日91app| 在线免费一区三区| 日韩理论片中文av| 粉嫩蜜臀av国产精品网站| 欧美变态tickle挠乳网站| 亚洲午夜日本在线观看| 97久久人人超碰| 国产精品视频九色porn| 国产精品一区二区不卡| 日韩欧美在线综合网| 香蕉成人伊视频在线观看| 91极品视觉盛宴| 亚洲色欲色欲www| 99精品欧美一区二区三区小说| 亚洲一级在线观看| 日本道免费精品一区二区三区| 国产三级精品三级在线专区| 国产主播一区二区三区| 欧美一区二区视频观看视频| 日韩精品一二三四| 91精品国产一区二区人妖| 亚洲成人av福利| 欧美精选一区二区| 丝袜诱惑制服诱惑色一区在线观看| 91福利区一区二区三区| 一区二区三区av电影| 一本到高清视频免费精品| ...xxx性欧美| 91视视频在线观看入口直接观看www | 26uuu色噜噜精品一区二区| 美女mm1313爽爽久久久蜜臀| 欧美一区二区大片| 久久成人麻豆午夜电影| 精品国产凹凸成av人网站| 国产精品一区一区| 中文字幕欧美激情| 91浏览器入口在线观看| 一区二区三区欧美亚洲| 欧美午夜在线观看| 日韩电影在线观看电影| 日韩欧美一级在线播放| 极品瑜伽女神91| 26uuuu精品一区二区| av亚洲精华国产精华精华| 亚洲精品亚洲人成人网在线播放| 欧美日韩一区不卡| 久久精品二区亚洲w码| 国产视频一区不卡| 91麻豆免费在线观看| 亚洲国产精品人人做人人爽| 日韩一区二区三区观看| 国产成人综合在线播放| 亚洲精选视频免费看| 制服丝袜一区二区三区| 国产精品小仙女|