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

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

?? dbtablegenerator.java

?? 將DB2數據庫里的數據導出為excel文件的java代碼
?? JAVA
字號:
 /*********************************************************************/
 /*(c) Copyright IBM Corp. 2004  All rights reserved.                 */
 /*                                                                   */
 /*This sample program is owned by International Business Machines    */
 /*Corporation or one of its subsidiaries ("IBM") and is copyrighted  */
 /*and licensed, not sold.                                            */
 /*                                                                   */
 /*You may copy, modify, and distribute this sample program in any    */
 /*form without payment to IBM,  for any purpose including developing,*/
 /*using, marketing or distributing programs that include or are      */
 /*derivative works of the sample program.                            */
 /*                                                                   */
 /*The sample program is provided to you on an "AS IS" basis, without */
 /*warranty of any kind.  IBM HEREBY  EXPRESSLY DISCLAIMS ALL         */
 /*WARRANTIES EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO*/
 /*THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTIC-*/
 /*ULAR PURPOSE. Some jurisdictions do not allow for the exclusion or */
 /*limitation of implied warranties, so the above limitations or      */
 /*exclusions may not apply to you.  IBM shall not be liable for any  */
 /*damages you suffer as a result of using, modifying or distributing */
 /*the sample program or its derivatives.                             */
 /*                                                                   */
 /*Each copy of any portion of this sample program or any derivative  */
 /*work,  must include a the above copyright notice and disclaimer of */
 /*warranty.                                                          */
 /*                                                                   */
 /*********************************************************************/

// Generates an Excel spreadsheet from a given table

package com.ibm.ExcelDB2;

import java.awt.*;
import java.awt.event.*;
import java.sql.SQLException;
import java.util.List;
import javax.swing.*;
import org.apache.poi.hssf.usermodel.*;

public class DBTableGenerator extends JFrame implements Runnable {
	Thread runner;
	JProgressBar current;
	JLabel generatingLabel;
	String spreadsheetName = "";
	SQLFacade sqlFacade;
	SpreadsheetTableModel spreadsheetModel;
	
	/**
	* Method centerDialog.
	* Centers the dialog box to appear in the middle of the screen
	*/
    private void centerDialog() {
        Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
        int x = ((int) screenSize.getWidth() - (int) (screenSize.getWidth() / 2)) - (int) (getWidth() / 2);
        int y = ((int) screenSize.getHeight() - (int) (screenSize.getHeight() / 2)) - (int) (getHeight() / 2);
        setLocation(x, y);
    }

	/**
	 * @see java.lang.Runnable#run()
	 */
	public void run() {
		String sqlRowInsertQuery = "";
		String sqlCreateQuery = ""; 
		try {		
			// Create the Table with the name and credentials provided
			// Calculate the number sql calls we will complete to track progress
			int goal = (spreadsheetModel.getRowCount() + 1) * 2;
			int progressToGoal = 0;
			// call constructor to create a progress bar
			DBTableGenerator frame = new DBTableGenerator(goal, spreadsheetName);			
			frame.addWindowListener(new WindowAdapter() {
				public void windowClosing(WindowEvent e) {
					// Allow close of progress window
				}
			});
			frame.pack();
			frame.centerDialog();
			frame.setVisible(true);
			// Create the new table by calling the standard Create SQL
			//  Ex CREATE TABLE ADMIN.EMAIL_ADDRESSES ( NAME CHARACTER (100) , EMAIL CHARACTER (100)   ) ;
			sqlCreateQuery = "CREATE TABLE " + sqlFacade.getUser() + "." + spreadsheetName + " ( ";
			String sqlColumnNames = " ( ";
			// Make sure to neglect the first column, which was used for placeholder row numbers
			for(int col = 0; col < (spreadsheetModel.getColumnCount()-1); col++) {
				if (col>0) {
					sqlCreateQuery += ", ";
					sqlColumnNames += ", ";
				}
				sqlCreateQuery += spreadsheetModel.getColumnNames().get(col);			
				sqlColumnNames += spreadsheetModel.getColumnNames().get(col);			
				switch(((Integer)(spreadsheetModel.getColumnTypes().get(col))).intValue()) {
					// Convert numeric types the equivalent floats (guaranteed to work for all number types)
					case HSSFCell.CELL_TYPE_NUMERIC: sqlCreateQuery += " FLOAT "; break;
					// No need to convert strings
					case HSSFCell.CELL_TYPE_STRING: sqlCreateQuery += " CHARACTER (100) "; break; 
					// Convert formulas to their string representations
					case HSSFCell.CELL_TYPE_FORMULA: sqlCreateQuery += " CHARACTER (100) "; break; 
					// No need to convert blank cells
					case HSSFCell.CELL_TYPE_BLANK: sqlCreateQuery += " CHARACTER (100) "; break;
					// We have covered all the cell types POI/HSSF produce above, but just in case we will provide error handling for any others by throwing an exception.
					default:
						System.out.println("Current SQL statement: " + sqlCreateQuery); 
						throw new SQLException();  				
				}
			}
			sqlCreateQuery += " ); ";
			sqlColumnNames += " ) ";
			// update the progress bar
			frame.current.setValue(1);
			// Run the sql query
			sqlFacade.executeUpdate(sqlCreateQuery);
			// update the progress bar
			frame.current.setValue(2);
			progressToGoal = 2;
			// Populate the new DB table row-by-row from the spreadsheetModel data, converting each column as appropriate
			for(int row = 0; row < spreadsheetModel.getRowCount(); row++) {
				sqlRowInsertQuery = "INSERT INTO " + sqlFacade.getUser() + "." + spreadsheetName + sqlColumnNames + " VALUES (";
				for(int col = 0; col < spreadsheetModel.getColumnCount()-1; col++) {
					if (col > 0) {
						sqlRowInsertQuery += ", ";
					}
					sqlRowInsertQuery += "'" + ((HSSFCell)(spreadsheetModel.getRow(row).get(col))).getStringCellValue() + "'";
				}
				sqlRowInsertQuery += " ); ";
				// update the progress bar
				progressToGoal++;
				frame.current.setValue(progressToGoal);
				// Run the sql query
				sqlFacade.executeUpdate(sqlRowInsertQuery);
				progressToGoal++;
				frame.current.setValue(progressToGoal);
			}
			// update the status label when finished
			frame.generatingLabel.setText(spreadsheetName + " Generated");
		} catch (Exception e) {
			System.out.println("Current Create SQL statement: " + sqlCreateQuery); 
			System.out.println("Current Insert SQL statement: " + sqlRowInsertQuery); 
			e.printStackTrace();	
		}
	}

	/**
	 * Method DBTableGenerator.
	 * constructor used to create progress bar
	 * @param goal
	 * @param spreadsheetName
	 */
	public DBTableGenerator(int goal, String spreadsheetName) {
		super("DB Table Generation Progress");
		JPanel top = new JPanel();		
		top.setPreferredSize(new Dimension(300,30));
		top.setLayout(new FlowLayout());
		current= new JProgressBar(0,goal);
		current.setValue(0);
		generatingLabel = new JLabel("Generating DB Table " + spreadsheetName,JLabel.CENTER);
		current.setStringPainted(true);
		top.add(current);		
		JPanel pane = new JPanel();
		pane.setLayout(new BorderLayout());
		pane.add("North", top);
		pane.add("South", generatingLabel);
		setContentPane(pane);
	}
	
	/**
	* Method DBTableGenerator.
	* constructor called by main program. 	A threaded model was used so one could see the progress of the DB table creation
	* @param spreadsheetName
	* @param spreadsheetModel
	* @param facade
	*/ 
	public DBTableGenerator(String spreadsheetName, SpreadsheetTableModel spreadsheetModel, SQLFacade facade) {
		this.spreadsheetName = spreadsheetName;
		this.spreadsheetModel = spreadsheetModel;
		this.sqlFacade = facade;
		try {
			Thread runner = new Thread(this);
			runner.start();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久免费看| 色天天综合色天天久久| 欧美成人vps| 国产一区二区三区日韩| 国产亚洲美州欧州综合国| 国产福利一区二区三区在线视频| 国产免费观看久久| 91免费版在线| 午夜伦理一区二区| 精品国产乱码久久久久久久久| 国产精品66部| 亚洲丝袜另类动漫二区| 精品视频999| 国产麻豆精品在线| 1000精品久久久久久久久| 精品视频1区2区3区| 国精产品一区一区三区mba桃花 | 欧美日韩在线观看一区二区 | 精品一区二区三区在线观看国产| 久久一日本道色综合| www.av亚洲| 视频一区在线播放| 欧美国产精品v| 在线精品视频免费播放| 美腿丝袜在线亚洲一区| 中文字幕日韩一区二区| 在线91免费看| 成人18视频日本| 日韩福利电影在线| 中文字幕亚洲区| 精品卡一卡二卡三卡四在线| 99re热视频精品| 另类的小说在线视频另类成人小视频在线 | 日韩国产精品久久久久久亚洲| 久久你懂得1024| 欧美日韩色一区| 成人激情午夜影院| 蜜臀va亚洲va欧美va天堂| 亚洲人成网站在线| 久久综合九色综合97_久久久| 在线观看精品一区| 高清国产一区二区三区| 麻豆视频一区二区| 亚洲国产精品自拍| 中文字幕日韩av资源站| 欧美成人高清电影在线| 欧美日韩精品一区二区三区四区 | 国产精品私房写真福利视频| 欧美精品欧美精品系列| 91影院在线观看| 国产精品一区二区无线| 日韩不卡一区二区| 亚洲自拍偷拍网站| 国产精品国产三级国产专播品爱网 | 国产丝袜欧美中文另类| 欧美电影免费观看高清完整版 | 久久国产夜色精品鲁鲁99| 亚洲夂夂婷婷色拍ww47 | 欧美日韩免费视频| 91啪亚洲精品| 北条麻妃国产九九精品视频| 狠狠色狠狠色综合日日91app| 亚洲一区二区3| 亚洲精品视频自拍| 国产精品久久毛片a| 久久久亚洲高清| 26uuu色噜噜精品一区二区| 日韩免费电影一区| 日韩精品在线一区二区| 日韩视频免费直播| 欧美一区二区免费视频| 欧美一级久久久久久久大片| 日韩欧美三级在线| 日韩欧美国产精品一区| 精品久久久久久久久久久久久久久久久 | 亚洲精品在线网站| 欧美xingq一区二区| 久久综合网色—综合色88| 久久综合资源网| 日本一区二区三区dvd视频在线| 国产亚洲va综合人人澡精品| 国产欧美一区在线| 最新久久zyz资源站| 亚洲免费视频中文字幕| 亚洲午夜日本在线观看| 日欧美一区二区| 美女久久久精品| 黄色成人免费在线| 懂色av一区二区三区免费观看| 国产不卡高清在线观看视频| 不卡的av电影| 在线视频国内自拍亚洲视频| 欧美精品一二三区| 日韩欧美黄色影院| 亚洲国产精品精华液2区45| 亚洲视频综合在线| 亚洲国产wwwccc36天堂| 日本在线不卡视频| 国产精品66部| 91国偷自产一区二区开放时间 | 日韩av电影天堂| 国内不卡的二区三区中文字幕| 成人久久久精品乱码一区二区三区| 成人精品国产免费网站| 欧美日韩国产大片| 久久亚洲私人国产精品va媚药| 中文字幕成人网| 日日夜夜一区二区| 国产一区二区不卡老阿姨| 99精品久久久久久| 欧美一级久久久| 国产精品国产三级国产aⅴ入口| 一区二区三区精品在线| 久久成人免费网| 91亚洲国产成人精品一区二三| 欧美精品乱码久久久久久按摩| 久久九九久久九九| 亚洲一区二区av电影| 国产福利精品导航| 欧美视频在线一区二区三区 | 99天天综合性| 欧美日韩视频在线第一区| 国产午夜亚洲精品午夜鲁丝片| 亚洲精品一二三四区| 国产露脸91国语对白| 91国在线观看| 国产欧美视频一区二区三区| 图片区小说区国产精品视频| 成人激情免费网站| 欧美成人高清电影在线| 一个色综合网站| 不卡大黄网站免费看| 精品国产亚洲在线| 日韩精品午夜视频| 91天堂素人约啪| 国产视频一区在线播放| 日韩和欧美的一区| 色综合久久九月婷婷色综合| 久久久久久麻豆| 日本不卡视频在线| 欧美日韩国产中文| 亚洲欧美成aⅴ人在线观看| 国产精品一区二区无线| 欧美videos大乳护士334| 亚洲妇女屁股眼交7| 91免费看`日韩一区二区| 国产欧美精品一区aⅴ影院| 麻豆91精品91久久久的内涵| 欧美久久婷婷综合色| 亚洲国产日韩a在线播放性色| 91亚洲精品一区二区乱码| 中文字幕第一区| 成人激情动漫在线观看| 久久久久国产精品厨房| 精品一区二区三区久久久| 欧美高清视频不卡网| 亚洲国产精品久久久久秋霞影院| 色中色一区二区| 亚洲人成在线播放网站岛国| 成人动漫中文字幕| 一色屋精品亚洲香蕉网站| 成人黄页在线观看| 国产精品二区一区二区aⅴ污介绍| 国产乱码精品一品二品| 久久先锋影音av| 国产馆精品极品| 国产精品丝袜黑色高跟| fc2成人免费人成在线观看播放| 国产嫩草影院久久久久| 成人精品国产免费网站| 中文字幕欧美一| 91成人网在线| 婷婷六月综合亚洲| 91精品国产aⅴ一区二区| 蜜臀久久99精品久久久久久9 | 青青草精品视频| 精品久久久久久久久久久久包黑料| 精品一区二区在线观看| 久久久久久久性| www.综合网.com| 亚洲激情av在线| 91麻豆精品91久久久久久清纯 | 欧美日韩国产综合一区二区三区| 亚洲成av人在线观看| 日韩精品资源二区在线| 国产麻豆午夜三级精品| 亚洲视频在线一区观看| 欧美绝品在线观看成人午夜影视| 另类成人小视频在线| 国产三级一区二区| 色狠狠一区二区| 日韩和欧美一区二区三区| 国产丝袜欧美中文另类| 在线一区二区视频| 久久精品国产一区二区三| 国产精品久久看| 制服丝袜一区二区三区| 福利一区二区在线| 亚洲国产精品久久久久秋霞影院| 精品久久国产字幕高潮|