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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? jdbcadapter.java

?? 這是一個用Jtable的一個學習的例子,內(nèi)容比較簡單,但很實用!
?? JAVA
字號:
/*
 * @(#)JDBCAdapter.java	1.16 04/07/26
 *
 * Copyright (c) 2004 Sun Microsystems, Inc. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * -Redistribution of source code must retain the above copyright notice, this
 *  list of conditions and the following disclaimer.
 *
 * -Redistribution in binary form must reproduce the above copyright notice,
 *  this list of conditions and the following disclaimer in the documentation
 *  and/or other materials provided with the distribution.
 *
 * Neither the name of Sun Microsystems, Inc. or the names of contributors may
 * be used to endorse or promote products derived from this software without
 * specific prior written permission.
 *
 * This software is provided "AS IS," without a warranty of any kind. ALL
 * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING
 * ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
 * OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MIDROSYSTEMS, INC. ("SUN")
 * AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE
 * AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS
 * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST
 * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL,
 * INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY
 * OF LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE,
 * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
 *
 * You acknowledge that this software is not designed, licensed or intended
 * for use in the design, construction, operation or maintenance of any
 * nuclear facility.
 */

/*
 * @(#)JDBCAdapter.java	1.16 04/07/26
 */

/**
 * 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 {
    System.out.println("finalize called");
    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 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);

  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
97se亚洲国产综合在线| wwwwxxxxx欧美| 91精品国产乱码久久蜜臀| 精品sm在线观看| 亚洲精品国产精华液| 麻豆91在线观看| 91在线观看一区二区| 91看片淫黄大片一级在线观看| 激情综合网最新| 不卡一卡二卡三乱码免费网站| 精品视频在线免费观看| 日本一区二区视频在线| 日韩av中文字幕一区二区三区| 99免费精品在线观看| 欧美一区二区三区婷婷月色| 最新国产精品久久精品| 国产福利91精品| 欧美一二三区精品| 一区二区免费看| 99精品热视频| 日本一区二区成人| 精品一区二区在线观看| 欧美一区二区国产| 午夜精品久久久久久不卡8050| 成人性视频免费网站| 久久久不卡网国产精品二区| 蜜桃一区二区三区在线| 欧美日本在线看| 伊人婷婷欧美激情| 不卡的电影网站| 国产欧美日韩不卡| 国产风韵犹存在线视精品| 日韩女优电影在线观看| 日本欧美一区二区三区| 欧美日韩激情在线| 亚洲午夜电影网| 欧美日韩一区在线观看| 亚洲国产精品一区二区www| 欧美性猛交xxxx乱大交退制版| 亚洲免费视频成人| av爱爱亚洲一区| 亚洲天天做日日做天天谢日日欢 | 亚洲免费在线电影| 成人免费毛片aaaaa**| 欧美激情一区在线| 成人av电影在线| 亚洲午夜激情av| 色哦色哦哦色天天综合| 中文字幕亚洲欧美在线不卡| 91亚洲国产成人精品一区二区三 | 国产精品免费网站在线观看| 国产精品66部| 国产精品久久久久精k8| 色婷婷综合久久久久中文 | 自拍偷拍亚洲欧美日韩| 91小视频在线免费看| 亚洲成人三级小说| 欧美一区二区视频在线观看2020| 男人操女人的视频在线观看欧美| 欧美一区二区高清| 懂色av一区二区三区蜜臀 | 97久久精品人人澡人人爽| 亚洲欧美精品午睡沙发| 欧美精品第1页| 国产成人精品一区二区三区网站观看| 国产亚洲综合在线| 91国产免费观看| 五月婷婷激情综合| 久久久久久免费网| 欧洲激情一区二区| 日韩成人免费看| 日本一区二区电影| 欧美乱妇15p| 国产xxx精品视频大全| 亚洲影院在线观看| 久久亚洲精品小早川怜子| 91亚洲精华国产精华精华液| 免费日韩伦理电影| 亚洲免费在线观看视频| 精品国产一区二区三区久久影院| 99久久99久久精品免费看蜜桃| 五月婷婷激情综合| 一色屋精品亚洲香蕉网站| 欧美一卡2卡三卡4卡5免费| 成人午夜碰碰视频| 蜜臀va亚洲va欧美va天堂| 综合久久给合久久狠狠狠97色 | 91成人国产精品| 麻豆国产精品视频| 亚洲尤物在线视频观看| 亚洲国产精品成人综合色在线婷婷| 欧美日韩精品免费观看视频| jizzjizzjizz欧美| 久久成人综合网| 亚洲va在线va天堂| 亚洲日本丝袜连裤袜办公室| 精品国产乱码久久久久久免费| 欧美日韩免费不卡视频一区二区三区| 国产乱人伦精品一区二区在线观看| 免费观看一级特黄欧美大片| 中文字幕一区在线观看| 久久综合久久99| 日韩欧美一级特黄在线播放| 91成人免费网站| jlzzjlzz欧美大全| 国产69精品一区二区亚洲孕妇| 毛片av一区二区| 日精品一区二区| 亚洲1区2区3区4区| 亚洲国产精品影院| 亚洲国产日韩精品| 亚洲精品视频在线看| 有码一区二区三区| 亚洲免费在线观看| 亚洲男人的天堂一区二区| 国产精品久久久久影院| 日本一区二区三区四区| 久久久久久亚洲综合影院红桃 | 日韩欧美中文一区二区| 欧美午夜理伦三级在线观看| 91麻豆免费视频| 色综合天天综合给合国产| 波多野结衣精品在线| 成人av免费在线观看| 成人午夜视频福利| 99视频在线精品| 色哟哟国产精品免费观看| 欧美亚洲国产一卡| 欧美高清视频不卡网| 欧美一二三四区在线| 久久久午夜电影| 中文字幕在线不卡| 亚洲一区中文日韩| 日韩电影在线一区| 黄色精品一二区| 波多野结衣的一区二区三区| 91丨porny丨首页| 欧美日产国产精品| 精品久久一区二区三区| 国产日韩视频一区二区三区| 国产精品麻豆视频| 亚洲国产毛片aaaaa无费看| 日本sm残虐另类| 丰满少妇久久久久久久| 在线观看视频欧美| 欧美一区三区二区| 欧美激情一区二区三区在线| 亚洲色图丝袜美腿| 日产精品久久久久久久性色| 国产毛片一区二区| 91国偷自产一区二区三区观看| 51午夜精品国产| 亚洲国产成人自拍| 亚洲一区二区三区中文字幕在线 | 精品免费国产二区三区| 国产精品人妖ts系列视频| 亚洲一区二区影院| 国产最新精品免费| 欧美日韩国产首页在线观看| 精品国产青草久久久久福利| 国产精品不卡在线观看| 日本欧美一区二区三区乱码| 99久久夜色精品国产网站| 欧美日韩国产影片| 国产精品久久影院| 久久国产日韩欧美精品| 色老汉一区二区三区| 久久综合狠狠综合| 午夜久久久久久| 99精品偷自拍| 久久久精品蜜桃| 日韩国产欧美三级| 在线一区二区三区| 国产亚洲成年网址在线观看| 天天综合色天天综合| 成人手机在线视频| 日韩女优毛片在线| 亚洲一区二区三区四区的| 国产精品一级片在线观看| 欧美久久久一区| 亚洲欧美色图小说| 成人av片在线观看| 久久九九影视网| 久久国产三级精品| 91精品国产一区二区三区| 一区二区三区丝袜| 成人激情文学综合网| 久久综合色婷婷| 国产专区欧美精品| 日韩视频一区二区在线观看| 亚洲国产精品久久人人爱蜜臀| 成人av影院在线| 欧美国产综合色视频| 国产成人自拍高清视频在线免费播放| 精品理论电影在线| 毛片基地黄久久久久久天堂| 欧美精品色综合| 日本不卡高清视频| 欧美裸体一区二区三区| 亚洲一区在线观看免费观看电影高清|