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

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

?? accessfiletype.java

?? 樹型類 accesstype
?? JAVA
字號:
/*
 * Created on 2004-12-2
 *
 * TODO To change the template for this generated file go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
package dalu.pui.model.filetype;

import java.sql.*;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;

import dalu.pui.model.access.*;

/**
 * @author xu_yihua
 *
 * TODO To change the template for this generated type comment go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
public class AccessFileType 
{
	private Connection con = null;
	private List lstFileType = new ArrayList();
	private List lstFileTypeTemp = new ArrayList();
	
	public AccessFileType()
	{
		this.con = DataBaseConnection.getConnection();
	}
	
	//功能說明:采用composite(組合)設計模式返回一個文件類型樹
	public AbstractNode getFileTypeTree() throws Exception
	{
		FileType fileType = new FileType();
		fileType.setFileTypeId("-1");
		fileType.setFileTypeName("所有類型");
		
		AbstractNode nodeRet = new FunctionNode(fileType);
		
		//加載所有的文件類型記錄
		GetFileTypeRows();
		
		lstFileTypeTemp.addAll(lstFileType);
		Iterator it = lstFileType.iterator();
		while (it.hasNext())
		{
			FunctionNode funNode = (FunctionNode)it.next();
			if (((FileType)funNode.getObj()).getFileTypeId().length() == 3) //根節點
				BuildFileTypeTreeNode(nodeRet, funNode);
		}
		lstFileTypeTemp.clear();
		return nodeRet;
	}
	
	//功能說明:根據文件類型代碼,得到子節點
	public Collection getSubFileType(String parFileTypeId) throws Exception
	{
		String strSql = "";
		Collection subFileTypeRet = new ArrayList();
		if (parFileTypeId.equals("-1"))
			strSql = "SELECT DOCTYPE_NO, DOCTYPE_ID, DOCTYPE, DOCTYPE_LEVEL, "
				+ "ISDEFAULT, PREFIX, REMARK from T_PUI_DOCTYPE "
				+ "where len(DOCTYPE_ID) = 3 "
				+ "order by DOCTYPE_ID, DOCTYPE_LEVEL";
		else
			strSql = "SELECT DOCTYPE_NO, DOCTYPE_ID, DOCTYPE, DOCTYPE_LEVEL, "
				+ "ISDEFAULT, PREFIX, REMARK from T_PUI_DOCTYPE "
				+ "where left(DOCTYPE_ID, len(DOCTYPE_ID) - 3) = '" + parFileTypeId + "' "
				+ "order by DOCTYPE_ID, DOCTYPE_LEVEL";
		Statement stmt = con.createStatement();
		ResultSet rstSubFileType = stmt.executeQuery(strSql);
		while (rstSubFileType.next())
		{
			FileType fileType = new FileType();
			fileType.setDbIncrement(rstSubFileType.getInt(1));
			fileType.setFileTypeId(rstSubFileType.getString(2));
			fileType.setFileTypeName(rstSubFileType.getString(3));
			fileType.setSerial(rstSubFileType.getInt(4));
			
			if (rstSubFileType.getInt(5) >= 1)
				fileType.setIsDefault(true);
			else
				fileType.setIsDefault(false);
			fileType.setPrefix(rstSubFileType.getString(6));
			fileType.setRemark(rstSubFileType.getString(7));
			
			if (rstSubFileType.getString(2).length() > 3)
				fileType.setParentTypeId(rstSubFileType.getString(2).substring(0, 
						rstSubFileType.getString(2).length() - 3));
			else
				fileType.setParentTypeId("-1");
			subFileTypeRet.add(fileType);
		}
		stmt.close();
		rstSubFileType.close();
		return subFileTypeRet;
	}
	
	//新增一個文件類型
	public int InsertFileType(FileType fileType) throws Exception
	{
		String maxFileTypeIdTemp = "", maxFileTypeIdLast = "";
		String strSql = "";
		int maxId = 0;
		try
		{
			maxFileTypeIdTemp = "000";
			//得到一個最大值,并加1
			if (fileType.getParentTypeId().equals("-1"))
			{
				strSql = "SELECT ISNULL(max(DOCTYPE_ID), 0) from T_PUI_DOCTYPE "
					+ "where len(DOCTYPE_ID) = 3";
				//在Access中判斷是否為空并賦值的函數是NZ用來替代碼SQL中的ISNULL
//				strSql = "SELECT NZ(max(DOCTYPE_ID), 0) from T_PUI_DOCTYPE "
//					+ "where len(DOCTYPE_ID) = 3";
			}
			else
			{
				strSql = "SELECT ISNULL(max(DOCTYPE_ID), 0) from T_PUI_DOCTYPE "
					+ "where left(DOCTYPE_ID, len(DOCTYPE_ID) - 3) = '" 
					+ fileType.getParentTypeId() + "' ";
//				strSql = "SELECT NZ(max(DOCTYPE_ID), 0) from T_PUI_DOCTYPE "
//					+ "where left(DOCTYPE_ID, len(DOCTYPE_ID) - 3) = '" 
//					+ fileType.getParentTypeId() + "' ";
//				for (int i = 0; i < fileType.getParentTypeId().length() + 3; i++)
//				{
//					maxFileTypeIdTemp += "0";
//				}
			}
			Statement stmt = con.createStatement();
			ResultSet rstMaxFileTypeId = stmt.executeQuery(strSql);
			while (rstMaxFileTypeId.next())
			{
				if (fileType.getParentTypeId().equals("-1"))
					maxId = rstMaxFileTypeId.getInt(1) + 1;
				else
				{
					String strTemp = String.valueOf(rstMaxFileTypeId.getInt(1));
					//因為字符串從0開始,所以只需要減4
					if (strTemp.length() > 3)
						strTemp = strTemp.substring(strTemp.length() - 4, 3);
					maxId = Integer.parseInt(strTemp) + 1;
				}
			}
			
			if (String.valueOf(maxId).length() == 4)
				throw new Exception("溢出錯誤!");
			
			rstMaxFileTypeId.close();
			stmt.close();
			
			maxFileTypeIdLast = maxFileTypeIdTemp.substring(0, 
					maxFileTypeIdTemp.length() - String.valueOf(maxId).length());
			
			if (fileType.getParentTypeId().equals("-1"))
				maxFileTypeIdLast += String.valueOf(maxId);
			else
				maxFileTypeIdLast = fileType.getParentTypeId() + maxFileTypeIdLast + String.valueOf(maxId);
				
			String strInsertSql = "insert into T_PUI_DOCTYPE(DOCTYPE_ID, DOCTYPE, DOCTYPE_LEVEL, "
				+ "ISDEFAULT, PREFIX, REMARK) values(?,?,?,?,?,?)";
			PreparedStatement pstat = con.prepareStatement(strInsertSql);
			pstat.setString(1, maxFileTypeIdLast);
			pstat.setString(2, fileType.getFileTypeName());
			pstat.setInt(3, fileType.getSerial());
			if (fileType.getIsDefault())
				pstat.setInt(4, 1);
			else
				pstat.setInt(4, 0);
			pstat.setString(5, fileType.getPrefix());
			pstat.setString(6, fileType.getRemark());
			pstat.executeUpdate();
			pstat.close();
			return 0;
		}
		catch(Exception e)
		{
			return 1;
		}
	}
	
	//刪除一個文件類型
	public int DeleteFileType(FileType fileType)
	{
		try
		{
			String strDelSql = "delete from T_PUI_DOCTYPE where DOCTYPE_ID like '"
				+ fileType.getFileTypeId() + "%'";
			Statement stmt = con.createStatement();
			stmt.execute(strDelSql);
			stmt.close();
			return 0;
		}
		catch(Exception e)
		{
			return 1;
		}
	}
	
	//更新一個文件類型
	public int UpdateFileType(FileType fileType)
	{
		try
		{
			String strInsertSql = "update T_PUI_DOCTYPE set DOCTYPE = ?, DOCTYPE_LEVEL = ?, "
				+ "ISDEFAULT = ?, PREFIX = ?, REMARK = ? where DOCTYPE_NO = ?";
			PreparedStatement pstat = con.prepareStatement(strInsertSql);
			pstat.setString(1, fileType.getFileTypeName());
			pstat.setInt(2, fileType.getSerial());
			if (fileType.getIsDefault())
				pstat.setInt(3, 1);
			else
				pstat.setInt(3, 0);
			pstat.setString(4, fileType.getPrefix());
			pstat.setString(5, fileType.getRemark());
			pstat.setInt(6, fileType.getDbIncrement());
			pstat.executeUpdate();
			pstat.close();
			return 0;
		}
		catch(Exception e)
		{
			return 1;
		}
	}
	
	//功能說明:根據文件類型Id,得到該文件類型的明細信息
	public FileType getFileTypeDetail(String fileTypeId) throws Exception
	{
		FileType fileType = new FileType();
		String strSql = "SELECT DOCTYPE_NO, DOCTYPE_ID, DOCTYPE, DOCTYPE_LEVEL, "
			+ "ISDEFAULT, PREFIX, REMARK from T_PUI_DOCTYPE "
			+ "where DOCTYPE_ID = '" + fileTypeId + "'";
		Statement stmt = con.createStatement();
		ResultSet rstFileTypeDetail = stmt.executeQuery(strSql);
		while (rstFileTypeDetail.next())
		{
			fileType.setDbIncrement(rstFileTypeDetail.getInt(1));
			fileType.setFileTypeId(rstFileTypeDetail.getString(2));
			fileType.setFileTypeName(rstFileTypeDetail.getString(3));
			fileType.setSerial(rstFileTypeDetail.getInt(4));
			
			if (rstFileTypeDetail.getInt(5) >= 1)
				fileType.setIsDefault(true);
			else
				fileType.setIsDefault(false);
			fileType.setPrefix(rstFileTypeDetail.getString(6));
			fileType.setRemark(rstFileTypeDetail.getString(7));
			if (rstFileTypeDetail.getString(2).length() > 3)
				fileType.setParentTypeId(rstFileTypeDetail.getString(2).substring(0, rstFileTypeDetail.getString(2).length() - 3));
			else
				fileType.setParentTypeId("-1");
		}
		stmt.close();
		rstFileTypeDetail.close();
		return fileType;
	}
	
	private void GetFileTypeRows() throws Exception
	{
		lstFileType.clear();
		String strSql = "SELECT DOCTYPE_ID, DOCTYPE, DOCTYPE_NO from T_PUI_DOCTYPE "
			+ "order by DOCTYPE_ID, DOCTYPE_LEVEL";
		Statement stmt = con.createStatement();
		ResultSet rstFileType = stmt.executeQuery(strSql);
		while (rstFileType.next())
		{
			FileType fileType = new FileType();
			fileType.setFileTypeId(rstFileType.getString(1));
			fileType.setFileTypeName(rstFileType.getString(2));
			fileType.setDbIncrement(rstFileType.getInt(3));
			FunctionNode funNode = new FunctionNode(fileType);
			lstFileType.add(funNode);
		}
		stmt.close();
		rstFileType.close();
	}
	
	private void BuildFileTypeTreeNode(AbstractNode parNode, AbstractNode childNode) throws Exception
	{
		String id = ((FileType)childNode.getObj()).getFileTypeId(); 
		parNode.add(childNode);
		for(int i = 0; i < lstFileTypeTemp.size(); i++)
		{
			FunctionNode funNode = (FunctionNode)lstFileTypeTemp.get(i);
			
			//3位表示一級
			if ((id.length() < ((FileType)funNode.getObj()).getFileTypeId().length())
					&& (id.equals(((FileType)funNode.getObj()).getFileTypeId().substring(0, ((FileType)funNode.getObj()).getFileTypeId().length() - 3))))
				BuildFileTypeTreeNode(childNode, funNode);
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品灌醉下药二区| 亚洲精品视频在线观看免费 | 欧美mv日韩mv亚洲| 日韩av不卡一区二区| 欧美大片一区二区三区| 久久99久久精品| 久久久久国产精品厨房| 成人一级视频在线观看| 亚洲色图欧洲色图| 欧美日韩国产综合视频在线观看 | 中文字幕欧美一| 欧美性猛片aaaaaaa做受| 免费观看成人鲁鲁鲁鲁鲁视频| 日韩美女在线视频| www.欧美.com| 三级一区在线视频先锋| 久久久久国产精品厨房| 91社区在线播放| 蜜桃91丨九色丨蝌蚪91桃色| 欧美国产日韩精品免费观看| 欧美日韩美少妇| 国产乱子轮精品视频| 日韩一区欧美一区| 欧美一二三区精品| 成人激情图片网| 免费精品视频最新在线| 国产精品久久久久影院老司| 欧美日韩亚洲另类| 国产99精品视频| 日韩电影在线观看电影| 国产精品嫩草99a| 日韩一区二区三区在线| 成人免费不卡视频| 免费看黄色91| 亚洲午夜一区二区三区| 久久久久久久精| 欧美精品一级二级三级| 99久久精品国产导航| 日韩国产一区二| 一区二区三区日韩| 久久久精品蜜桃| 日韩三区在线观看| 在线欧美一区二区| 不卡视频免费播放| 国产综合一区二区| 日韩精品91亚洲二区在线观看 | 久久综合色之久久综合| 欧美视频中文字幕| a级高清视频欧美日韩| 美女免费视频一区二区| 午夜精品久久久久久久久| 国产精品美女www爽爽爽| 欧美xxxx老人做受| 欧美一区二区视频在线观看2020 | 亚洲国产一区二区在线播放| 国产亚洲综合av| 精品久久久久久久久久久久包黑料 | 中文字幕二三区不卡| 欧美tickling网站挠脚心| 欧美视频一区在线| 色天使色偷偷av一区二区| 不卡的av在线| 成人深夜视频在线观看| 国产一区高清在线| 久久国产精品99久久久久久老狼| 午夜av一区二区| 亚洲成人你懂的| 亚洲一区二区不卡免费| 亚洲欧美在线另类| 国产精品水嫩水嫩| 国产精品欧美精品| 国产精品高潮呻吟| 亚洲视频一区二区在线| 一区在线观看视频| 成人欧美一区二区三区小说| 中文字幕第一页久久| 国产精品日产欧美久久久久| 国产精品免费网站在线观看| 亚洲欧洲精品一区二区三区| 亚洲欧洲日本在线| 一区二区三区久久久| 一区二区三区中文字幕电影| 一区二区久久久| 午夜精品久久久久久久99水蜜桃| 天天综合天天做天天综合| 日韩国产精品久久| 国产一区二区三区久久久| 成人一道本在线| 91美女片黄在线观看91美女| 色综合色狠狠综合色| 欧美电影在哪看比较好| 日韩欧美第一区| 国产欧美日产一区| 亚洲欧美视频在线观看视频| 亚洲高清视频的网址| 久久国产免费看| 成人一区二区三区在线观看| 91麻豆6部合集magnet| 欧美日韩一区二区三区四区五区 | 国产午夜久久久久| 亚洲天堂av一区| 日欧美一区二区| 国产成人精品影视| 欧美午夜宅男影院| 久久久久久久久久久久久久久99| 国产精品卡一卡二卡三| 亚洲成精国产精品女| 激情文学综合网| 在线视频你懂得一区二区三区| 91精品国产综合久久久久久漫画 | 欧美高清视频一二三区| 久久亚洲综合色| 亚洲另类春色校园小说| 午夜视频一区二区三区| 国内久久精品视频| 91黄色免费看| 国产午夜亚洲精品午夜鲁丝片| 一区二区日韩电影| 国产一区二区三区综合| 欧美四级电影在线观看| 久久伊99综合婷婷久久伊| 亚洲一区成人在线| 成人视屏免费看| 日韩午夜激情电影| 一个色综合网站| 成人a级免费电影| 欧美电视剧免费全集观看| 国产精品福利av| 美女在线观看视频一区二区| 色视频一区二区| 久久久精品天堂| 免费高清视频精品| 欧美三级蜜桃2在线观看| 国产精品伦理一区二区| 久久国产欧美日韩精品| 欧美美女bb生活片| 亚洲男同性恋视频| www.激情成人| 日本一区二区三区电影| 美女视频免费一区| 在线不卡中文字幕| 亚洲制服欧美中文字幕中文字幕| 国内精品在线播放| 欧美肥妇bbw| 午夜精品国产更新| 在线观看日韩精品| 中文字幕在线观看一区| 国产成人av电影在线观看| 欧美一区二区福利视频| 一区二区三区成人| 在线观看精品一区| 一级女性全黄久久生活片免费| 不卡电影免费在线播放一区| 久久久久久一级片| 国产剧情av麻豆香蕉精品| 欧美电影免费观看高清完整版| 午夜精品免费在线| 欧美日韩精品欧美日韩精品| 亚洲制服丝袜在线| 欧美亚州韩日在线看免费版国语版| 中文字幕成人av| 国产风韵犹存在线视精品| 精品国精品国产尤物美女| 九一九一国产精品| 2017欧美狠狠色| 国产麻豆午夜三级精品| 国产亚洲欧美日韩俺去了| 国产精品一区二区三区99 | 久久久不卡网国产精品二区 | 国产一区二区0| 久久免费国产精品| 国产91丝袜在线观看| 国产精品三级av| 色综合天天综合网国产成人综合天| 成人欧美一区二区三区在线播放| 91视频com| 亚洲成av人片| 欧美大片免费久久精品三p| 国产美女精品一区二区三区| 国产日韩欧美综合在线| 99久久伊人精品| 亚洲www啪成人一区二区麻豆| 欧美一区二区在线免费播放| 麻豆精品视频在线| 国产欧美日韩在线看| 99精品一区二区| 性久久久久久久| 久久这里只有精品首页| 成人动漫在线一区| 午夜视频一区二区| 久久午夜免费电影| 色综合久久中文综合久久牛| 亚洲成人www| 久久久精品天堂| 91女人视频在线观看| 欧美bbbbb| 国产精品对白交换视频 | 色综合久久久久久久| 午夜视频一区二区三区| 久久久久国产精品免费免费搜索|