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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? jdbcadapter.java

?? 這是一個(gè)在Java開(kāi)發(fā)的JSP進(jìn)銷(xiāo)存管理系統(tǒng)源碼
?? JAVA
字號(hào):
/* * @(#)JDBCAdapter.java	1.12 01/12/03 * * Copyright 2002 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. *//** * An adaptor, transforming the JDBC interface to the TableModel interface. * * @version 1.20 09/25/97 * @author Philip Milne */import java.util.Vector;import java.sql.*;import javax.swing.table.AbstractTableModel;import javax.swing.event.TableModelEvent;public class JDBCAdapter extends AbstractTableModel {    Connection          connection;    Statement           statement;    ResultSet           resultSet;    String[]            columnNames = {};    Vector		rows = new Vector();    ResultSetMetaData   metaData;    public JDBCAdapter(String url, String driverName,                       String user, String passwd) {        try {            Class.forName(driverName);            System.out.println("Opening db connection");            connection = DriverManager.getConnection(url, user, passwd);            statement = connection.createStatement();        }        catch (ClassNotFoundException ex) {            System.err.println("Cannot find the database driver classes.");            System.err.println(ex);        }        catch (SQLException ex) {            System.err.println("Cannot connect to this database.");            System.err.println(ex);        }     }    public void executeQuery(String query) {        if (connection == null || statement == null) {            System.err.println("There is no database to execute the query.");            return;        }        try {            resultSet = statement.executeQuery(query);            metaData = resultSet.getMetaData();            int numberOfColumns =  metaData.getColumnCount();            columnNames = new String[numberOfColumns];            // Get the column names and cache them.            // Then we can close the connection.            for(int column = 0; column < numberOfColumns; column++) {                columnNames[column] = metaData.getColumnLabel(column+1);            }            // Get all rows.            rows = new Vector();            while (resultSet.next()) {                Vector newRow = new Vector();                for (int i = 1; i <= getColumnCount(); i++) {	            newRow.addElement(resultSet.getObject(i));                }                rows.addElement(newRow);            }            //  close(); Need to copy the metaData, bug in jdbc:odbc driver.            fireTableChanged(null); // Tell the listeners a new table has arrived.        }        catch (SQLException ex) {            System.err.println(ex);        }    }    public void close() throws SQLException {        System.out.println("Closing db connection");        resultSet.close();        statement.close();        connection.close();    }    protected void finalize() throws Throwable {        close();        super.finalize();    }    //////////////////////////////////////////////////////////////////////////    //    //             Implementation of the TableModel Interface    //    //////////////////////////////////////////////////////////////////////////    // MetaData    public String getColumnName(int column) {        if (columnNames[column] != null) {            return columnNames[column];        } else {            return "";        }    }    public Class getColumnClass(int column) {        int type;        try {            type = metaData.getColumnType(column+1);        }        catch (SQLException e) {            return super.getColumnClass(column);        }        switch(type) {        case Types.CHAR:        case Types.VARCHAR:        case Types.LONGVARCHAR:            return String.class;        case Types.BIT:            return Boolean.class;        case Types.TINYINT:        case Types.SMALLINT:        case Types.INTEGER:            return Integer.class;        case Types.BIGINT:            return Long.class;        case Types.FLOAT:        case Types.DOUBLE:            return Double.class;        case Types.DATE:            return java.sql.Date.class;        default:            return Object.class;        }    }    public String getColumnClassStr(int column) {        int type;        try {            type = metaData.getColumnType(column+1);        }        catch (SQLException e) {            return " ";        }        switch(type) {        case Types.CHAR:        case Types.VARCHAR:        case Types.LONGVARCHAR:            return "String";        case Types.BIT:            return "Boolean";        case Types.TINYINT:        case Types.SMALLINT:        case Types.INTEGER:            return "int";        case Types.BIGINT:            return "long";        case Types.FLOAT:        case Types.DOUBLE:            return "float";        case Types.DATE:            return "String";        default:            return "String";        }    }        public boolean isCellEditable(int row, int column) {        try {            return metaData.isWritable(column+1);        }        catch (SQLException e) {            return false;        }    }    public int getColumnCount() {        return columnNames.length;    }    // Data methods    public int getRowCount() {        return rows.size();    }    public Object getValueAt(int aRow, int aColumn) {        Vector row = (Vector)rows.elementAt(aRow);        return row.elementAt(aColumn);    }    public String dbRepresentation(int column, Object value) {        int type;        if (value == null) {            return "null";        }        try {            type = metaData.getColumnType(column+1);        }        catch (SQLException e) {            return value.toString();        }        switch(type) {        case Types.INTEGER:        case Types.DOUBLE:        case Types.FLOAT:            return value.toString();        case Types.BIT:            return ((Boolean)value).booleanValue() ? "1" : "0";        case Types.DATE:            return value.toString(); // This will need some conversion.        default:            return "\""+value.toString()+"\"";        }    }    public void setValueAt(Object value, int row, int column) {        try {            String tableName = metaData.getTableName(column+1);            // Some of the drivers seem buggy, tableName should not be null.            if (tableName == null) {                System.out.println("Table name returned null.");            }            String columnName = getColumnName(column);            String query =                "update "+tableName+                " set "+columnName+" = "+dbRepresentation(column, value)+                " where ";            // We don't have a model of the schema so we don't know the            // primary keys or which columns to lock on. To demonstrate            // that editing is possible, we'll just lock on everything.            for(int col = 0; col<getColumnCount(); col++) {                String colName = getColumnName(col);                if (colName.equals("")) {                    continue;                }                if (col != 0) {                    query = query + " and ";                }                query = query + colName +" = "+                    dbRepresentation(col, getValueAt(row, col));            }            System.out.println(query);            System.out.println("Not sending update to database");            // statement.executeQuery(query);        }        catch (SQLException e) {            //     e.printStackTrace();            System.err.println("Update failed");        }        Vector dataRow = (Vector)rows.elementAt(row);        dataRow.setElementAt(value, column);    }}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲情趣在线观看| 综合分类小说区另类春色亚洲小说欧美 | 国产成人av一区二区三区在线观看| 自拍视频在线观看一区二区| 日韩一区二区精品在线观看| 97久久精品人人爽人人爽蜜臀| 日韩国产精品久久久久久亚洲| 国产精品免费av| 日韩精品资源二区在线| 在线视频一区二区三区| 国产xxx精品视频大全| 日韩高清一级片| 伊人婷婷欧美激情| 国产精品视频免费| 日韩精品一区二区三区蜜臀| 欧美午夜不卡在线观看免费| 成人免费视频app| 狠狠色丁香婷综合久久| 丝袜美腿高跟呻吟高潮一区| 亚洲综合一二区| 国产精品的网站| 欧美国产激情二区三区 | 国产亚洲精品精华液| 91精品国产丝袜白色高跟鞋| 精品视频在线视频| 91色.com| 91视频精品在这里| 99re在线视频这里只有精品| 成人性生交大片免费看中文网站| 精品一区二区三区在线播放视频 | av电影在线观看不卡 | 91精品国产综合久久久蜜臀图片| 91麻豆产精品久久久久久| 懂色av中文字幕一区二区三区| 久久99久久99小草精品免视看| 青青草精品视频| 日韩制服丝袜av| 日日嗨av一区二区三区四区| 亚洲图片欧美色图| 亚洲亚洲精品在线观看| 亚洲综合激情另类小说区| 亚洲欧美另类小说| 亚洲欧美自拍偷拍| 日韩理论电影院| 亚洲免费视频成人| 亚洲一级片在线观看| 亚洲gay无套男同| 亚洲一级二级在线| 午夜电影网亚洲视频| 日本午夜精品一区二区三区电影| 欧美aaaaaa午夜精品| 久久国产欧美日韩精品| 黑人巨大精品欧美黑白配亚洲| 九九精品一区二区| 国产乱人伦精品一区二区在线观看| 国产精品综合视频| 成人a免费在线看| 色综合天天综合色综合av| 色天天综合色天天久久| 欧美色区777第一页| 日韩一区二区在线看| 国产午夜一区二区三区| 国产精品天天看| 亚洲靠逼com| 日韩精彩视频在线观看| 久久69国产一区二区蜜臀| 国产福利一区二区三区视频在线| 成人国产精品免费网站| 99久久精品一区| 欧美日韩国产综合草草| 日韩一区二区免费在线观看| 久久久不卡网国产精品二区| 中文字幕亚洲一区二区av在线| 亚洲一区二区三区四区在线观看 | 亚洲一区国产视频| 免费高清成人在线| 成人av在线电影| 欧美电影影音先锋| 国产日韩综合av| 亚洲综合激情网| 狠狠色丁香婷婷综合久久片| 色综合视频一区二区三区高清| 欧美一区二区视频免费观看| 国产精品亲子乱子伦xxxx裸| 亚洲最新在线观看| 精品一区二区三区在线观看| 91极品美女在线| 久久天天做天天爱综合色| 一区二区久久久久| 国内精品伊人久久久久av影院| 92精品国产成人观看免费 | 一区2区3区在线看| 激情伊人五月天久久综合| 91蝌蚪porny| 精品国产91九色蝌蚪| 夜夜嗨av一区二区三区四季av | 国产成人在线看| 91精品啪在线观看国产60岁| 自拍偷拍国产精品| 国产一区91精品张津瑜| 欧美日韩国产区一| 国产精品三级久久久久三级| 久久99热这里只有精品| 欧美中文字幕一区二区三区亚洲| 久久久久99精品国产片| 日韩精品五月天| 欧美性猛交xxxx黑人交 | 久久疯狂做爰流白浆xx| 欧美唯美清纯偷拍| 国产精品国产三级国产普通话三级| 久久精品国产亚洲5555| 欧美剧情电影在线观看完整版免费励志电影| 国产日韩欧美精品电影三级在线 | 色视频一区二区| 欧美高清在线视频| 国产美女精品人人做人人爽| 91精品国产综合久久精品app| 亚洲精品自拍动漫在线| 国产成人亚洲精品狼色在线| 久久夜色精品国产欧美乱极品| 青青国产91久久久久久| 337p亚洲精品色噜噜| 亚洲一线二线三线久久久| 色婷婷激情一区二区三区| 中文字幕一区二区视频| k8久久久一区二区三区| 国产免费成人在线视频| 国产美女娇喘av呻吟久久| 久久青草欧美一区二区三区| 国产在线精品一区二区夜色| 日韩三级免费观看| 美女视频黄免费的久久| 日韩美一区二区三区| 久久超碰97中文字幕| 91精品在线一区二区| 免费久久99精品国产| 欧美一二区视频| 美女一区二区三区在线观看| 欧美一级日韩免费不卡| 日本aⅴ亚洲精品中文乱码| 91蝌蚪porny| 亚洲mv在线观看| 欧美亚日韩国产aⅴ精品中极品| 自拍偷拍国产精品| 成人开心网精品视频| 亚洲男人的天堂av| 91美女精品福利| 亚洲欧美日韩综合aⅴ视频| 成人黄色av网站在线| 亚洲激情自拍偷拍| 在线一区二区三区四区五区| 亚洲男人天堂av| 欧美在线不卡视频| 美日韩黄色大片| 精品国产髙清在线看国产毛片| 蜜臀av国产精品久久久久 | 日本韩国一区二区| 亚洲最快最全在线视频| 欧美天天综合网| 亚洲成a人片在线不卡一二三区 | 国产精品一区二区你懂的| 久久久久国产精品麻豆| 成人av网在线| 一区二区三区在线观看视频| 91精品婷婷国产综合久久性色 | www.成人在线| 有码一区二区三区| 欧美电影免费观看高清完整版在线 | 欧美性生活一区| 日韩精品成人一区二区三区| 精品日韩在线一区| 国产精品自拍三区| 欧美激情综合五月色丁香| 欧美亚洲尤物久久| 日本视频一区二区| 国产亚洲一区字幕| 97se亚洲国产综合自在线| 国产精品久久久久久亚洲毛片 | 欧美一级在线免费| 国产高清无密码一区二区三区| 中文字幕亚洲精品在线观看| 91色乱码一区二区三区| 欧美aaaaaa午夜精品| 国产日产亚洲精品系列| 一本久久综合亚洲鲁鲁五月天| 天天影视网天天综合色在线播放| 日韩精品中文字幕一区二区三区| 成人精品视频一区二区三区| 亚洲成人av一区| 2020国产精品自拍| 欧美三级三级三级| 国产一级精品在线| 一区二区三区自拍| 久久精品一区二区三区四区| 日本精品一区二区三区高清| 国产乱码精品一区二区三区五月婷| 136国产福利精品导航| 精品成人一区二区三区四区| 91免费看片在线观看| 看片的网站亚洲|