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

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

?? categoryservice.java

?? shopping 一個簡單的ERP項目...綜合運用了jsp+javabean+Servlet+css等
?? JAVA
字號:
package com.bjsxt.shopping.category;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import com.bjsxt.shopping.util.DB;

public class CategoryService {
	
	private static CategoryService service;
	
	private CategoryService() {}
	
	public static CategoryService getInstance() {
		if(service == null) {
			service = new CategoryService();
		}
		return service;
	}
	
	/**
	 * 拿到所有的根類別
	 * @return
	 */
	public List<Category> getTopCategories() {
		List<Category> categories = new ArrayList<Category>();
		Connection conn = DB.getConn();
		Statement stmt = DB.getStatement(conn);
		ResultSet rs = DB.getResultSet(stmt, "select * from category where grade = 1");
		try {
			while (rs.next()) {
				Category c = this.getCategoryFromRs(rs);
				categories.add(c);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(conn);
		}
		
		return categories;
	}
	
	public List<Category> getChilds(int id) {
		List<Category> categories = new ArrayList<Category>();
		Connection conn = DB.getConn();
		Statement stmt = DB.getStatement(conn);
		ResultSet rs = DB.getResultSet(stmt, "select * from category where pid = " + id);
		try {
			while (rs.next()) {
				Category c = this.getCategoryFromRs(rs);
				categories.add(c);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(conn);
		}
		
		return categories;
	}
	
	//List<Category> categories = null;
	/*
	public synchronized List<Category> getCategories() {
		if(categories != null) return categories;
		
		categories = new ArrayList<Category>();
		Connection conn = DB.getConn();
		String sql = "select * from category order by cno";
		Statement stmt = DB.getStatement(conn);
		ResultSet rs = DB.getResultSet(stmt, sql);
		try {
			while (rs.next()) {
				Category c = this.getCategoryFromRs(rs);
				categories.add(c);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(rs);
			DB.close(stmt);
			DB.close(conn);
		}
		return categories;
	}
	*/
	
	
	public List<Category> getCategories() {
		List<Category> categories = new ArrayList<Category>();
		Connection conn = DB.getConn();
		String sql = "select * from category order by cno";
		Statement stmt = DB.getStatement(conn);
		ResultSet rs = DB.getResultSet(stmt, sql);
		try {
			while (rs.next()) {
				Category c = this.getCategoryFromRs(rs);
				categories.add(c);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(rs);
			DB.close(stmt);
			DB.close(conn);
		}
		return categories;
	}
	
	private Category getCategoryFromRs(ResultSet rs) {
		Category c = new Category();
		try {
			c.setId(rs.getInt("id"));
			c.setPid(rs.getInt("pid"));
			c.setName(rs.getString("name"));
			c.setDescr(rs.getString("descr"));
			c.setCno(rs.getInt("cno"));
			c.setGrade(rs.getInt("grade"));
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return c;
	}
	
	public void delete(int id) {
		
	}
	
	public void delete(Category c) {
		delete(c.getId());
	}
	
	public void add(Category c) {
		Connection conn = DB.getConn();
		try {
			conn.setAutoCommit(false);
		} catch (SQLException e1) {
			e1.printStackTrace();
		}
		
		String sql = "insert into category values (null, ?, ?, ?, ?, ?)";
		PreparedStatement pstmt = DB.prepare(conn, sql);
		try {
			int cno = getNextCno(conn, c);
					
			pstmt.setInt(1, c.getPid());
			pstmt.setString(2, c.getName());
			pstmt.setString(3, c.getDescr());
			pstmt.setInt(4, cno);
			pstmt.setInt(5, c.getGrade());
			pstmt.executeUpdate();
			conn.commit();
		} catch (SQLException e) {
			try {
				conn.rollback();
			} catch (SQLException e1) {
				e1.printStackTrace();
			}
			e.printStackTrace();
		} finally {
			try {
				conn.setAutoCommit(true);
			} catch (SQLException e) {
				e.printStackTrace();
			}
			DB.close(pstmt);
			DB.close(conn);
		}

	}
	
	private int getNextCno(Connection conn, Category c) {
		int cno = -1;
		
		String sqlMax = "select max(cno) from category where pid = " + c.getPid();
		Statement stmtMax = DB.getStatement(conn);
		ResultSet rsMax = DB.getResultSet(stmtMax, sqlMax);
		
		try {
			rsMax.next();
			int cnoMax = rsMax.getInt(1);
System.out.println(cnoMax);			
			//計算節點的基數,如用兩位表示就是100,三位表示就是1000等
			int baseNumber = (int)Math.pow(10, Category.LEVEL_LENGTH);
			//構建cstr要加上的數字
			int numberToAdd = (int)Math.pow(baseNumber, Category.MAX_GRADE - c.getGrade());
			
			if(cnoMax == 0) { //要加入的節點是該父親下面的第一個子節點
				if(c.getPid() == 0) { //最頂層節點
					cno = numberToAdd;
				} else { //其他層節點
					int parentCno = getParentCno(conn, c); //拿到父親代表串
					cno = parentCno + numberToAdd;
				}
			} else { //加入的節點不是該父親下面的第一個
				cno = cnoMax + numberToAdd;
			}
			
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(rsMax);
			DB.close(stmtMax);
		}
			
		return cno;
	}

	private int getParentCno(Connection conn, Category child) {
		String sql = "select cno from category where id = " + child.getPid();
		Statement stmt = DB.getStatement(conn);
		ResultSet rs = DB.getResultSet(stmt, sql);
		
		int cno = -1;
		
		try {
			rs.next();
			cno = rs.getInt(1);
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(rs);
			DB.close(stmt);
		}
		return cno;
	}

	public void update(Category c) {
		c.update();
	}
	
	public void updateCategory(int id, String name, String descr) {
		
	}
	
	public Category loadById(int id) {
		Category c = null;
		Connection conn = DB.getConn();
		String sql = "select * from category where id = " + id;
		Statement stmt = DB.getStatement(conn);
		ResultSet rs = DB.getResultSet(stmt, sql);
		try {
			if (rs.next()) {
				c = this.getCategoryFromRs(rs);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			DB.close(rs);
			DB.close(stmt);
			DB.close(conn);
		}
		return c;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区三区高清免费看看| 99re成人精品视频| 久久久精品综合| 丰满白嫩尤物一区二区| 中文字幕在线不卡国产视频| 99久久精品久久久久久清纯| 一区二区三区日韩欧美精品| 欧美午夜不卡在线观看免费| 日韩av不卡一区二区| 2023国产精品自拍| 99视频超级精品| 偷拍日韩校园综合在线| 精品福利一区二区三区免费视频| 国产精品99久久久久久久vr| **欧美大码日韩| 欧美日韩激情在线| 国产麻豆成人传媒免费观看| 日韩美女视频一区二区| 欧美挠脚心视频网站| 国内精品写真在线观看| 国产精品国产自产拍高清av| 色av一区二区| 九色综合国产一区二区三区| 亚洲欧洲精品一区二区精品久久久| 欧洲视频一区二区| 激情五月激情综合网| 综合分类小说区另类春色亚洲小说欧美| 色菇凉天天综合网| 韩国理伦片一区二区三区在线播放 | 亚洲mv在线观看| 精品乱人伦一区二区三区| 成人va在线观看| 免费成人在线视频观看| 中文字幕国产精品一区二区| 欧美精品日日鲁夜夜添| 丁香婷婷综合网| 日本中文字幕一区| 最新中文字幕一区二区三区| 日韩精品一区二区三区四区| av成人免费在线观看| 男女性色大片免费观看一区二区 | 91久久香蕉国产日韩欧美9色| 蜜臂av日日欢夜夜爽一区| 亚洲人成精品久久久久| 精品日韩一区二区三区 | 麻豆国产精品一区二区三区 | 国产成人在线色| 亚洲成精国产精品女| 中文字幕av在线一区二区三区| 欧美一区日本一区韩国一区| 一本大道久久a久久综合婷婷| 狠狠色丁香婷综合久久| 天天综合天天做天天综合| 亚洲国产精品二十页| 日韩精品一区二区三区视频| 欧美日韩成人激情| 99久久精品国产观看| 国产成人午夜电影网| 毛片av一区二区三区| 亚洲成av人片在线观看无码| 亚洲精品免费播放| 亚洲免费成人av| 亚洲美女屁股眼交3| 亚洲丝袜精品丝袜在线| 久久精品一区二区三区不卡牛牛 | 欧美伊人久久大香线蕉综合69 | 亚洲一区二区不卡免费| 国产精品久久看| 国产精品免费av| 国产欧美精品一区aⅴ影院| 2024国产精品视频| 精品久久久久久久久久久久包黑料 | 99国产精品久久久久| 久久精品久久久精品美女| 亚洲成a天堂v人片| 亚洲第四色夜色| 婷婷中文字幕一区三区| 亚洲影视在线观看| 丝袜亚洲另类欧美| 日韩成人一级大片| 久久国产精品色婷婷| 国产综合色在线| 丰满少妇久久久久久久| 99re免费视频精品全部| 91国偷自产一区二区三区成为亚洲经典 | 欧美天天综合网| 欧美视频在线一区| 欧美一区二区三区色| 精品奇米国产一区二区三区| 久久蜜桃香蕉精品一区二区三区| 国产午夜精品在线观看| 国产精品久久久久久久久果冻传媒 | 国产精品国产精品国产专区不片 | 欧美一区二区三区系列电影| 日韩视频在线一区二区| 国产日韩精品久久久| 国产精品久久久久久久裸模| 一区二区三区在线看| 亚洲国产视频一区二区| 亚洲成人www| 日本亚洲免费观看| 国产剧情一区二区| 成人av网站免费观看| 日本伦理一区二区| 国产成人亚洲综合a∨婷婷图片| 成人国产电影网| 成人小视频免费在线观看| 在线精品视频一区二区| 3atv在线一区二区三区| 欧美精品一区二区三区在线播放| 久久精品欧美日韩| 亚洲欧美日韩久久精品| 欧美bbbbb| 国产精品69毛片高清亚洲| 久久99精品久久久| 国产成人在线电影| 白白色 亚洲乱淫| 在线观看www91| 26uuu欧美| 国产精品久久久久精k8 | 亚洲成人综合视频| 久久国产精品露脸对白| 国产老肥熟一区二区三区| 日本精品免费观看高清观看| 欧美影院午夜播放| 国产成人精品免费网站| 99国产欧美久久久精品| 欧美日韩一区二区三区视频 | 秋霞午夜av一区二区三区| 福利一区在线观看| 欧美视频在线观看一区| xfplay精品久久| 中文字幕亚洲一区二区va在线| 亚洲午夜在线电影| 国产综合一区二区| 色婷婷综合激情| 久久久噜噜噜久久中文字幕色伊伊 | 欧美大片顶级少妇| 亚洲成在人线免费| 国产成人啪午夜精品网站男同| 91精选在线观看| 一区二区三区中文字幕| 国内不卡的二区三区中文字幕 | 欧美人妖巨大在线| 成人免费在线视频观看| 九九**精品视频免费播放| 欧美日韩成人在线| 一区在线播放视频| 成人精品视频一区| 欧美日免费三级在线| 国产精品乱子久久久久| 国产盗摄精品一区二区三区在线| 欧美在线影院一区二区| 亚洲欧美另类图片小说| 久99久精品视频免费观看| 日韩一级黄色大片| 亚洲综合一区二区| 色哟哟在线观看一区二区三区| 在线不卡一区二区| 五月激情综合网| 欧美日韩国产高清一区二区| 亚洲chinese男男1069| 亚洲国产日日夜夜| 久久99这里只有精品| 国产欧美日产一区| 色国产综合视频| 免费看精品久久片| 亚洲第一激情av| 日韩欧美国产综合| 春色校园综合激情亚洲| 国产精一区二区三区| 在线观看av一区| 亚洲欧美怡红院| 国产露脸91国语对白| 久久久精品免费网站| 麻豆国产精品一区二区三区| 精品国产三级电影在线观看| 亚洲国产欧美在线| 欧美日韩在线三区| 亚洲一区二区视频在线| 欧美日韩免费视频| 一区二区三区中文在线观看| 欧美人xxxx| 久久超碰97中文字幕| 欧美mv日韩mv国产网站app| 国产精品99久久久| 久久久久亚洲蜜桃| 成人国产亚洲欧美成人综合网| 91麻豆精品国产91久久久久久久久| 亚洲欧美另类小说视频| 欧美日本一道本在线视频| 亚洲视频免费观看| 欧美美女一区二区三区| 久久国内精品视频| 久久免费国产精品| 在线区一区二视频| 亚洲第一成人在线| 国产日韩欧美制服另类| 成人免费毛片高清视频| 亚洲国产乱码最新视频|