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

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

?? dbutils.java

?? DWR 3級聯(lián)動代碼 基于DWR 的整合 是一個不錯的例子
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
				rsmd.getColumnType(index) == Types.BIGINT) {
			m.put(columnName, rs.getInt(columnName));
		} else if (rsmd.getColumnType(index) == Types.NUMERIC ) {
			// System.out.println(rsmd.getPrecision(i+1)+" "+ rsmd.getScale(i+1));
			if(rsmd.getScale(index) == 0){ // 整數(shù)返回Integer
				m.put(columnName, rs.getInt(columnName));
			} else { // 小數(shù)返回BigDecimal
				m.put(columnName, rs.getBigDecimal(columnName));
			}
		} else {
//			System.out.println("rs.getObject(columnName)" + rs.getObject(columnName).getClass() + " " + rsmd.getColumnType(index));
			m.put(columnName, rs.getObject(columnName));
		}
	}
	
	/**
	 * 查詢唯一記錄
	 * @param sql
	 * @param params
	 * @return 找到返回一個Map對象,否則返回null
	 */
	public Map uniqueResult (String sql, Object... params) {
		Connection conn = getCurrentConnection();
		PreparedStatement pstmt = null;
		ResultSet rs = null;
		try {
			pstmt = conn.prepareStatement(sql);
			parseParameters(pstmt, params);
			rs = pstmt.executeQuery();
			ResultSetMetaData rsmd = rs.getMetaData();
			int columnCount = rsmd.getColumnCount();
			Map m = new IgnoreCaseHashMap();
			boolean found = false;
			if(rs.next()) {
				for(int i = 0; i < columnCount; i++) {
					parseResultSet(rs, rsmd, m, i+1);
				}
				found = true;
			}
			if(rs.next()){
				throw new RuntimeException("返回記錄不唯一");
			}
			return (found)?m:null;
		} catch (SQLException e) {
			throw new RuntimeException("執(zhí)行查詢時失敗",e);
		} finally {
			closeRs(rs);
			closeStmt(pstmt);
		}
	}
	
	/**
	 * 該方法只能用于oracle 10g 數(shù)據(jù)庫
	 * @param blobIs
	 * @param blob
	 */
	public void write2Blob(InputStream blobIs, Blob blob) {
		OutputStream blobOs = null;
		try {
			blobOs = blob.setBinaryStream(0L);
			is2Os(blobIs, blobOs, 4096);
		} catch (Exception e) {
			throw new RuntimeException("Blob 寫入失敗",e);
		} finally {
			try { if( blobOs != null) blobOs.close(); } catch (IOException e) { }
			try { if( blobIs != null) blobIs.close(); } catch (IOException e) { }
		}	
	}

	/**
	 * 該方法只能用于oracle 10g 數(shù)據(jù)庫
	 * @param clobIs
	 * @param clob
	 */
	public void write2Clob(InputStream clobIs, Clob clob) {
		Writer clobWriter = null;
		Reader clobReader = null;
		try {
			clobWriter = clob.setCharacterStream(0L);
			clobReader = new InputStreamReader(clobIs, "UTF-8");
			reader2Writer(clobReader, clobWriter, 4096);
		} catch (Exception e) {
			throw new RuntimeException("Clob 寫入失敗",e);
		} finally {
			try { if( clobReader != null) clobReader.close(); } catch (IOException e) { }
			try { if( clobWriter != null) clobWriter.close(); } catch (IOException e) { }
			try { if( clobIs != null) clobIs.close(); } catch (IOException e) { }
		}
	}
	
	/**
	 * 該方法能用于oracle 9i和10g XE 數(shù)據(jù)庫
	 * @param clobIs
	 * @param rs
	 * @param columnName
	 */
	public void write2CLOB(InputStream clobIs, ResultSet rs, String columnName) {
		Writer clobWriter = null;
		Reader clobReader = null;
		try {
			CLOB c = ((OracleResultSet) rs).getCLOB(columnName);
			clobWriter = c.setCharacterStream(0L);
			clobReader = new InputStreamReader(clobIs, "UTF-8");
			reader2Writer(clobReader, clobWriter, c.getBufferSize());
		} catch (Exception e) {
			throw new RuntimeException("CLOB 寫入失敗",e);
		} finally {
			try { if( clobReader != null) clobReader.close(); } catch (IOException e) { }
			try { if( clobWriter != null) clobWriter.close(); } catch (IOException e) { }
			try { if( clobIs != null) clobIs.close(); } catch (IOException e) { }
		}		
	}

	private void reader2Writer(Reader clobReader, Writer clobWriter, int size) throws Exception {
		try {
			char[] cbuffer = new char[size];
			int length = -1;
			
			while ((length = clobReader.read(cbuffer)) != -1) {
				clobWriter.write(cbuffer, 0, length);
			}
		} catch (Exception e) {
			throw e;
		} finally {
			try { if( clobReader != null) clobReader.close(); } catch (IOException e) { }
		}		
	}
	
	/**
	 * 該方法能用于oracle 9i和10g XE 數(shù)據(jù)庫
	 * @param blobIs
	 * @param rs
	 * @param columnName
	 */
	public void write2BLOB(InputStream blobIs, ResultSet rs, String columnName) {
		OutputStream blobOs = null;
		try {
			BLOB b = ( (OracleResultSet) rs).getBLOB(columnName);
			blobOs = b.setBinaryStream(0L);
			is2Os(blobIs, blobOs, b.getBufferSize());
		} catch (Exception e) {
			throw new RuntimeException("BLOB 寫入失敗",e);
		} finally {
			try { if( blobOs != null) blobOs.close(); } catch (IOException e) { }
			try { if( blobIs != null) blobIs.close(); } catch (IOException e) { }
		}
	}
	
	public void readBLOB(ResultSet rs, String columnName, OutputStream os) {
		InputStream blobIs = null;
		try {
			BLOB blob = ((OracleResultSet) rs).getBLOB(columnName);
			blobIs = blob.getBinaryStream();
			is2Os(blobIs, os, blob.getBufferSize());
		} catch (Exception e) {
			throw new RuntimeException("BLOB 讀取失敗",e);
		} finally {
			try { if( os != null) os.close(); } catch (IOException e) { }
			try { if( blobIs != null) blobIs.close(); } catch (IOException e) { }
		}		
	}
	
	public void readCLOB(ResultSet rs, String columnName, Writer writer) {
		Reader clobReader = null;
		try {
			CLOB c = ( (OracleResultSet) rs ).getCLOB(columnName);
			clobReader = c.characterStreamValue();
			reader2Writer(clobReader, writer, c.getBufferSize());
		} catch (Exception e) {
			throw new RuntimeException("CLOB 讀取失敗",e);
		} finally {
			try { if( writer != null) writer.close(); } catch (IOException e) { }
			try { if( clobReader != null) clobReader.close(); } catch (IOException e) { }
		}		
	}

	public void is2Os(InputStream is, OutputStream os, int size) throws IOException {
		byte[] buffer = new byte[size];
		int length = -1;
		while ((length = is.read(buffer)) != -1) {
			os.write(buffer, 0, length);
		}
	}
	
	/**
	 * 該方法用于執(zhí)行DDL等SQL語句
	 * @param sql
	 */
	public void execute(String sql){
		execute(sql, false);
	}
	
	public void execute(String sql, boolean ignoreError) {
		Connection conn = getCurrentConnection();
		Statement stmt = null;
		try {
			stmt = conn.createStatement();
			stmt.execute(sql);
		} catch (SQLException e) {
			if(! ignoreError) {
				throw new RuntimeException("執(zhí)行SQL時失敗",e);
			}
		} finally {
			closeStmt(stmt);
		}
	}
	
	public CallableStatement getCallableStatement(String sql) {
		Connection conn = getCurrentConnection();
		CallableStatement cstmt = null;
		try {
			cstmt = conn.prepareCall(sql);
			return cstmt;
		} catch (SQLException e) {
			throw new RuntimeException("執(zhí)行存儲過程時失敗",e);
		} 
	}
	
	public java.sql.Date getSQLNow() {
		return new java.sql.Date(new java.util.Date().getTime());
	}

	public java.sql.Date getSQLDate(java.util.Date time) {
		return (time == null) ? null : new java.sql.Date(time.getTime());
	}

	public java.util.Date getUtilDate(java.sql.Timestamp time) {
		return (time == null) ? null : new java.util.Date(time.getTime());
	}

	public java.util.Date getUtilDate(java.sql.Date time) {
		return (time == null) ? null : new java.util.Date(time.getTime());
	}
	
	/**
	 * 用于收集PreparedStatement的參數(shù),用法:
	 * ParameterCollection ps = new ParameterCollection();
	 * ps.append(對象參數(shù)1).append(對象參數(shù)2);
	 * Object params = ps.getParameterArray(); // 返回參數(shù)數(shù)組
	 * @author yihang
	 *
	 */
	public static class ParameterCollection {
		private List params = new ArrayList();
		public ParameterCollection append(Object param){
			this.params.add(param);
			return this;
		}
		public Object[] getParameterArray(){
			return params.toArray(new Object[]{});
		}
		public void clear() {
			this.params.clear();
		}
	}
	
	private String getCountSQL(String originalSQL){
		int index = originalSQL.toLowerCase().indexOf(" from");
		return new StringBuilder()
					.append("SELECT COUNT(*) as _count")
					.append(originalSQL.substring(index)).toString();
	}
	
	/**
	 * 執(zhí)行查詢某SQL語句返回結(jié)果的總記錄數(shù)
	 * @param sql
	 * @param params
	 * @return
	 */
	public int countResult (String sql, Object... params) {
		Map map = uniqueResult(getCountSQL(sql), params);
		return (map==null)?0:(Integer)map.get("_count");
	}
	
	/**
	 * 為原有SQL語句加入top,例如 執(zhí)行:
	 * insertTop4SQLServer("select * from A where b = ?", 10)
	 * 結(jié)果返回:
	 * select top 10 from A where b = ?
	 * @param originalSQL
	 * @return
	 */
	public String insertTop4SQLServer(String originalSQL, int top) {
		String after = originalSQL.substring("select".length());
		return new StringBuilder().append("SELECT top ").append(top).append(after).toString(); 
	}
	
	public static void main(String[] args) throws SQLException {
		ResultSet rs = null;
		
		// 增
//		DBUtils.getInstance().executeUpdate(
//				"insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) " +
//					"values (?,?,?,?,?,?,?,?)", 
//				8889,"TOM","SALESMAN",7369,
//				new java.sql.Date(new Date().getTime()),
//				new BigDecimal("3000.00"),null,20);
		
		// 刪
//		DBUtils.getInstance().executeUpdate("delete from emp where empno=?", 
//				7499);
		
		// 改
//		DBUtils.getInstance().executeUpdate(
//				"update emp set sal=?,job=? where empno=?", 
//				new BigDecimal("10000.00"),"MANAGER",8888);
		
		// 查
		
//		rs = DBUtils.getInstance().executeQuery("select empno,ename,sal from emp where sal > ?", 	
//				new BigDecimal("2000"));
//		while(rs.next()){
//			System.out.print(rs.getInt(1));
//			System.out.print(" ");
//			System.out.print(rs.getString(2));
//			System.out.print(" ");
//			System.out.println(rs.getString(3));
//		}
//		DBUtils.getInstance().closeRs(rs);
		
//		rs = DBUtils.getInstance().executeQuery("select empno,ename,comm from emp where comm is ?", 	
//				new Object[]{null});
//		while(rs.next()){
//			System.out.print(rs.getInt(1));
//			System.out.print(" ");
//			System.out.print(rs.getString(2));
//			System.out.print(" ");
//			System.out.println(rs.getString(3));
//		}
//		DBUtils.getInstance().closeRs(rs);
		
//		List list = DBUtils.getInstance().list(
//				"select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like ?", "S%");
//		for (Iterator i = list.iterator(); i.hasNext();) {
//			Map m = (Map) i.next();
//			Set columnNames = m.keySet();
//			for (Iterator j = columnNames.iterator(); j.hasNext();) {
//				String key = (String) j.next();
//				Object value = m.get(key);
//				System.out.print(key + ":" + value + "," + ((value==null)?"":value.getClass()));
//			}
//			System.out.println("");
//		}
		
		Calendar c = Calendar.getInstance();
		c.set(Calendar.YEAR, 1982);
		c.set(Calendar.MONTH, 0);
		List list = DBUtils.getInstance().list(
				"select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where hiredate > ?", new java.sql.Date(c.getTime().getTime()));
		for (Iterator i = list.iterator(); i.hasNext();) {
			Map m = (Map) i.next();
			Set columnNames = m.keySet();
			for (Iterator j = columnNames.iterator(); j.hasNext();) {
				String key = (String) j.next();
				Object value = m.get(key);
				System.out.print(key + ":" + value + " " + ((value==null)?"":value.getClass()));
			}
			System.out.println("");
		}
		
//		Map m = DBUtils.getInstance().uniqueResult(
//				"select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename = ?", "SMITH");
//		Set columnNames = m.keySet();
//		for (Iterator j = columnNames.iterator(); j.hasNext();) {
//			String key = (String) j.next();
//			Object value = m.get(key);
//			System.out.print(key + ":" + value + " " );//+ ((value==null)?"":value.getClass()));
//		}
		
//		Map m = DBUtils.getInstance().uniqueResult(
//				"select count(*) total from emp", null);
//		Set columnNames = m.keySet();
//		for (Iterator j = columnNames.iterator(); j.hasNext();) {
//			String key = (String) j.next();
//			Object value = m.get(key);
//			System.out.print(key + ":" + value + " " );//+ ((value==null)?"":value.getClass()));
//		}
		
		DBUtils.getInstance().commit();
		DBUtils.getInstance().closeAll();
	}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
香蕉av福利精品导航| 午夜精品视频一区| 欧美一级夜夜爽| 国产91精品精华液一区二区三区| 亚洲精品乱码久久久久久| 精品日产卡一卡二卡麻豆| 在线观看一区二区视频| 国产精品456| 日产国产欧美视频一区精品| 亚洲欧美在线视频观看| 久久久精品天堂| 欧美一级国产精品| 在线观看91视频| 色综合色狠狠综合色| 大美女一区二区三区| 另类小说欧美激情| 日韩精品一区第一页| 亚洲视频综合在线| 国产精品嫩草影院com| 久久亚洲综合色一区二区三区| 欧美日韩一区三区| 色老汉一区二区三区| 成人免费视频caoporn| 精品无人码麻豆乱码1区2区| 三级一区在线视频先锋| 亚洲少妇30p| 国产精品久久国产精麻豆99网站| 久久婷婷色综合| 日韩美一区二区三区| 在线综合+亚洲+欧美中文字幕| 欧日韩精品视频| 欧美少妇一区二区| 在线视频中文字幕一区二区| 97久久超碰精品国产| av网站一区二区三区| 国产成人啪午夜精品网站男同| 国产一区二区三区久久久 | 亚洲欧美日韩国产一区二区三区| 国产人成一区二区三区影院| 久久综合色婷婷| 精品国产sm最大网站| 欧美videossexotv100| 精品久久久久久无| 精品国产一区二区三区久久久蜜月 | 日本在线不卡一区| 亚洲成av人**亚洲成av**| 亚洲国产欧美日韩另类综合| 亚洲午夜激情av| 中文字幕巨乱亚洲| 久久综合一区二区| 中文字幕不卡三区| 国产精品素人一区二区| 国产精品色在线| 国产欧美一区二区在线观看| 久久精子c满五个校花| 2021中文字幕一区亚洲| 欧美一区二区在线播放| 欧美久久免费观看| 欧美精品一二三| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲精品乱码久久久久久| 中文字幕在线一区免费| 欧美国产1区2区| 欧美国产精品久久| 亚洲视频一区在线观看| 亚洲综合图片区| 婷婷久久综合九色综合伊人色| 午夜视频在线观看一区二区三区| 亚洲视频香蕉人妖| 亚洲成a人v欧美综合天堂 | 国产不卡视频一区二区三区| 国产成人免费视| 琪琪久久久久日韩精品| 韩国av一区二区三区| 国产精品 欧美精品| 成人h动漫精品一区二区| 91在线观看地址| 欧美日韩三级视频| 欧美一区二区视频在线观看| 欧美电影免费观看高清完整版在线 | 国产欧美精品一区二区色综合 | 欧美国产一区视频在线观看| 国产精品传媒在线| 五月综合激情网| 久久99久久99小草精品免视看| 国产精品一品二品| 91在线看国产| 91精品国产手机| 亚洲精品在线免费播放| 亚洲欧洲综合另类| 亚洲一区二区黄色| 亚洲欧美偷拍另类a∨色屁股| 日本成人在线电影网| 麻豆传媒一区二区三区| 成人网在线播放| 精品久久久久久久久久久久久久久久久| 国产精品系列在线| 激情久久久久久久久久久久久久久久| 99在线精品免费| 2欧美一区二区三区在线观看视频| 亚洲色图欧美在线| 国产成人精品综合在线观看| 69av一区二区三区| 一区二区三区在线视频免费观看| 国产一区二区三区蝌蚪| 欧美一区二区三区免费| 亚洲亚洲人成综合网络| av男人天堂一区| 亚洲国产精品精华液2区45| 午夜免费久久看| 99re视频这里只有精品| 精品处破学生在线二十三| 有坂深雪av一区二区精品| 国产揄拍国内精品对白| 在线精品观看国产| 国产精品久久久久久久裸模| 美女网站一区二区| 欧美亚洲免费在线一区| 日韩欧美美女一区二区三区| 视频一区二区不卡| 色网综合在线观看| 国产日韩欧美不卡在线| 美女视频一区二区| 欧美性色欧美a在线播放| 国产精品福利在线播放| 成人免费高清在线| 中文字幕五月欧美| 成人动漫精品一区二区| 精品国产91久久久久久久妲己 | 亚洲成人综合在线| 91久久国产最好的精华液| 国产精品日韩精品欧美在线| 久久精品久久综合| 色婷婷亚洲精品| 精品久久国产老人久久综合| 偷拍一区二区三区| 91浏览器在线视频| 国产精品传媒入口麻豆| 国产suv精品一区二区三区| 欧美一级二级三级蜜桃| 亚洲影视在线播放| 色欧美乱欧美15图片| 国产精品的网站| 成人国产精品免费观看| 欧美激情在线观看视频免费| 久久99国产精品久久99果冻传媒| 正在播放一区二区| 亚洲精品视频一区| 色综合一区二区| 一区二区三区四区亚洲| 99精品视频中文字幕| 中文字幕一区二| 91在线精品秘密一区二区| 国产精品久久毛片av大全日韩| 国产一区二区精品久久99| 国产欧美一区二区精品仙草咪| 国产乱子轮精品视频| 国产视频亚洲色图| 国产激情偷乱视频一区二区三区| 日韩欧美亚洲一区二区| 色婷婷综合久久久中文字幕| 日本一区免费视频| 91玉足脚交白嫩脚丫在线播放| 欧美成va人片在线观看| 国产suv一区二区三区88区| 国产精品久久福利| 欧美三日本三级三级在线播放| 免费在线观看一区| 久久综合九色综合97_久久久| 国产91对白在线观看九色| 1000部国产精品成人观看| 欧美高清视频不卡网| 黄页网站大全一区二区| 亚洲视频一区在线| 欧美日韩二区三区| 国产综合色精品一区二区三区| 国产视频一区二区在线| 欧美日韩国产综合久久| 天堂在线一区二区| 国产精品久久久久久久久久免费看| 国产成人久久精品77777最新版本| 亚洲人成精品久久久久久| 欧美不卡一二三| heyzo一本久久综合| 亚洲一区二区三区爽爽爽爽爽| 欧美v日韩v国产v| 国产福利精品导航| 五月天精品一区二区三区| 久久一区二区视频| 91久久精品国产91性色tv| 美女看a上一区| 中文字幕一区二区在线观看| 91精品午夜视频| 国产成人无遮挡在线视频| 一区二区三区美女| 久久网这里都是精品| 欧美色图一区二区三区| 日韩精品午夜视频| 亚洲另类色综合网站| 精品国产免费人成电影在线观看四季 |