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

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

?? main.java

?? 個人Blog java編寫的Blog可以直接使用!
?? JAVA
字號:
/*
 *  Main.java
 *  
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Library General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 *  
 *  Author: Winter Lau
 *  http://dlog4j.sourceforge.net
 *  
 */
package com.liusoft.dlog4j.upgrade;

import java.net.URL;
import java.sql.Timestamp;
import java.util.Date;
import java.util.HashMap;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;

import com.liusoft.dlog4j.beans.BookmarkBean;
import com.liusoft.dlog4j.beans.CatalogBean;
import com.liusoft.dlog4j.beans.DiaryBean;
import com.liusoft.dlog4j.beans.DiaryOutlineBean;
import com.liusoft.dlog4j.beans.DiaryReplyBean;
import com.liusoft.dlog4j.beans.LinkBean;
import com.liusoft.dlog4j.beans.MessageBean;
import com.liusoft.dlog4j.beans.SiteBean;
import com.liusoft.dlog4j.beans.UserBean;
import com.liusoft.util.db.Hibernate;

/**
 * 遷移程序入口
 * @author liudong
 */
public class Main{

	static SiteBean site ;
	
	static HashMap userids = new HashMap();
	static HashMap catalogids = new HashMap();
	static HashMap logids = new HashMap();
	
	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception{
		int site_id = 1;
		try{
			site_id = Integer.parseInt(args[0]);
		}catch(Exception e){}
		System.out.println("============== Press any key to begin upgrade to site #"+site_id+" =================");
		System.in.read();
		site = new SiteBean(site_id);

		URL xml = Main.class.getResource("old_hibernate.cfg.xml");
		old_hb = Hibernate.init(xml.getPath());
		xml = Main.class.getResource("new_hibernate.cfg.xml");
		new_hb = Hibernate.init(xml.getPath());

		Session old_ssn = old_hb.getSession();
		Session new_ssn = new_hb.getSession();
		Transaction tx = new_ssn.beginTransaction();
		
		try{
			upgradeUsers(old_ssn, new_ssn);
			System.out.println("============== Users upgraded.=================");
			
			upgradeLinks(old_ssn, new_ssn);
			System.out.println("============== Links upgraded.=================");
			
			upgradeCatalogs(old_ssn, new_ssn);
			System.out.println("============== Catalogs upgraded.=================");
			
			upgradeLogs(old_ssn, new_ssn);
			System.out.println("============== Articles upgraded.=================");
			
			upgradeReplies(old_ssn, new_ssn);
			System.out.println("============== Replies upgraded.=================");

			upgradeBookmarks(old_ssn, new_ssn);
			System.out.println("============== Bookmarks upgraded.=================");
			
			upgradeMessages(old_ssn, new_ssn);
			System.out.println("============== Messages upgraded.=================");
			
			tx.commit();
			System.out.println("============== DLOG4J upgraded.=================");
		}catch(Exception e){
			e.printStackTrace();
			tx.rollback();
		}finally{
			old_hb.destroy();
			new_hb.destroy();
		}
				
	}
	
	/**
	 * 遷移日記分類
	 */
	protected static void upgradeCatalogs(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM CatalogForm c ORDER BY c.id ASC");
		List catalogs = q.list();
		
		for(int i=0;i<catalogs.size();i++){
			CatalogForm cform = (CatalogForm)catalogs.get(i);
			CatalogBean cbean = new CatalogBean();
			cbean.setSite(site);
			cbean.setCreateTime(new Date());
			cbean.setDetail(cform.getDetail());
			cbean.setName(cform.getName());
			cbean.setArticleCount(0);
			cbean.setSortOrder(cform.getOrder());
			if(cform.getType()==CatalogForm.TYPE_OWNER)
				cbean.setType(CatalogBean.TYPE_OWNER);
			else
				cbean.setType(CatalogBean.TYPE_GENERAL);
			new_ssn.save(cbean);
			catalogids.put(new Integer(cform.getId()), cbean);	
			System.out.println("Catalog: " + cform.getId() + " -> " + cbean.getId());
		}
	}
	
	/**
	 * 遷移日記
	 */
	protected static void upgradeLogs(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM LogForm c ORDER BY c.id ASC");
		List logs = q.list();
		
		for(int i=0;i<logs.size();i++){
			LogForm log = (LogForm)logs.get(i);
			DiaryBean dbean = new DiaryBean();
			dbean.setCatalog((CatalogBean)catalogids.get(new Integer(log.getCategory())));
			//owner
			dbean.setOwner((UserBean)userids.get(new Integer(log.getOwnerId())));
			if(StringUtils.isNotEmpty(log.getAuthor()))
				dbean.setAuthor(log.getAuthor());
			else
				dbean.setAuthor(log.getOwner().getDisplayName());
			dbean.setAuthorUrl(StringUtils.abbreviate(log.getAuthorUrl(),100));
			dbean.setClientType("HTML".equalsIgnoreCase(log.getClientType())?0:1);
			if(log.getContent().length()>20000)
				dbean.setContent(log.getContent().substring(0, 20000));
			else
				dbean.setContent(log.getContent());
			dbean.setCreateTime(log.getLogTime());
			dbean.setStatus(log.getStatus());
			if("ptcl".equalsIgnoreCase(log.getWeather()))
				dbean.setWeather("ptcloudy");
			else
				dbean.setWeather(log.getWeather());
			
			dbean.setViewCount(log.getViewCount());
			dbean.setReplyCount(log.getReplies().size());
			dbean.setReplyNotify(log.getReplyNotify());
			dbean.setTitle(log.getTitle());
			dbean.setSite(site);
			dbean.setRefUrl(log.getRefUrl());
			dbean.setMoodLevel(log.getMoodLevel());
			dbean.setKeyword(log.getSearchKey());
			dbean.setClientAddr("127.0.0.1");
			if(log.getStatus()==LogForm.STATUS_DELETED)
				dbean.setStatus(DiaryBean.STATUS_DELETED);
			else if(log.getStatus()==LogForm.STATUS_DRAFT)
				dbean.setStatus(DiaryBean.STATUS_DRAFT);
			else
				dbean.setStatus(DiaryBean.STATUS_NORMAL);
			
			if(dbean.getStatus()==DiaryBean.STATUS_NORMAL){
				dbean.getCatalog().incArticleCount(1);
				dbean.getOwner().getCount().incArticleCount(1);
			}
			
			new_ssn.save(dbean);
			logids.put(new Integer(log.getId()), new Integer(dbean.getId()));
			System.out.println("Diary: " + log.getId() + " -> " + dbean.getId());		
		}
	}
	
	/**
	 * 遷移評論
	 */
	protected static void upgradeReplies(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM ReplyForm c ORDER BY c.id ASC");
		List replies = q.list();
		
		for(int i=0;i<replies.size();i++){
			ReplyForm rform = (ReplyForm)replies.get(i);
			DiaryReplyBean rbean = new DiaryReplyBean();
			rbean.getClient().setAddr("127.0.0.1");
			
			rbean.setDiary(new DiaryOutlineBean(((Integer)logids.get(new Integer(rform.getLogId()))).intValue()));
			rbean.setUser((UserBean)userids.get(new Integer(rform.getAuthor().getId())));
			
			rbean.getUser().getCount().incArticleReply(1);
			
			rbean.setAuthor(rform.getAuthor().getDisplayName());
			rbean.setAuthorEmail(rform.getAuthor().getEmail());
			rbean.setAuthorURL(StringUtils.abbreviate(rform.getAuthor().getHomePage(),100));
			if(rform.getContent().length()>10000)
				rbean.setContent(rform.getContent().substring(0, 10000));
			else
				rbean.setContent(rform.getContent());
			rbean.setReplyTime(rform.getWriteTime());
			rbean.setSite(site);
			new_ssn.save(rbean);
			System.out.println("Reply: " + rform.getId() + " -> " + rbean.getId());		
		}			
	}
	
	/**
	 * 用戶遷移
	 */
	protected static void upgradeUsers(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM UserForm u ORDER BY u.id ASC");
		List users = q.list();
		
		for(int i=0;i<users.size();i++){
			UserForm user = (UserForm)users.get(i);	
			UserBean ubean = new UserBean();
			//導入到指定的site
			ubean.setSite(site);
			ubean.setName(user.getLoginName());
			ubean.setNickname(user.getDisplayName());
			ubean.setPassword(user.getPassword());
			ubean.setRegTime(new Timestamp(user.getRegTime().getTime()));
			ubean.setResume(user.getResume());
			ubean.setEmail(user.getEmail());
			ubean.setHomePage(StringUtils.abbreviate(user.getHomePage(),50));
			ubean.setLastAddr(user.getLastAddr());
			if(user.getLastTime()!=null)
				ubean.setLastTime(new Timestamp(user.getLastTime().getTime()));
			new_ssn.save(ubean);
			//保存新舊用戶的編號對應關系
			userids.put(new Integer(user.getId()), ubean);
			System.out.println("User: " + user.getId() + " -> " + ubean.getId());
		}
	}

	/**
	 * 友情鏈接遷移
	 */
	protected static void upgradeLinks(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM LinkForm l ORDER BY l.id ASC");
		List links = q.list();		
		for(int i=0;i<links.size();i++){
			LinkForm link = (LinkForm)links.get(i);	
			LinkBean lbean = new LinkBean();
			lbean.setCreateTime(link.getCreateTime());
			lbean.setSiteId(site.getId());
			lbean.setSortOrder(link.getOrder());
			lbean.setTitle(link.getTitle());
			lbean.setUrl(link.getUrl());
			if("HTML".equalsIgnoreCase(link.getMode()))
				lbean.setType(LinkBean.TYPE_HTML);
			else
				lbean.setType(LinkBean.TYPE_XML);
			new_ssn.save(lbean);
			System.out.println("LINK: " + link.getId() + " -> " + lbean.getId());
		}
	}
	
	/**
	 * 留言遷移
	 * @param old_ssn
	 * @param new_ssn
	 */
	protected static void upgradeMessages(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM MessageForm l ORDER BY l.id ASC");
		List msgs = q.list();		
		for(int i=0;i<msgs.size();i++){
			MessageForm msg = (MessageForm)msgs.get(i);	
			MessageBean mbean = new MessageBean();
			mbean.setContent(msg.getContent());
			mbean.setReadTime(msg.getReadTime());
			mbean.setSendTime(msg.getSendTime());
			mbean.setStatus(msg.getStatus());
			mbean.setFromUser((UserBean)userids.get(new Integer(msg.getFromUserId())));
			mbean.setToUser((UserBean)userids.get(new Integer(msg.getToUserId())));
			new_ssn.save(mbean);
			System.out.println("MESSAGE: " + msg.getId() + " -> " + mbean.getId());
		}
	}

	/**
	 * 書簽遷移
	 * @param old_ssn
	 * @param new_ssn
	 */
	protected static void upgradeBookmarks(Session old_ssn, Session new_ssn){
		Query q = old_ssn.createQuery("FROM BookMarkBean l ORDER BY l.id ASC");
		List bmbs = q.list();		
		for(int i=0;i<bmbs.size();i++){
			BookMarkBean bm = (BookMarkBean)bmbs.get(i);	
			BookmarkBean mbean = new BookmarkBean();
			mbean.setCreateTime(bm.getCreateTime());
			mbean.setOwner((UserBean)userids.get(new Integer(bm.getUserId())));
			mbean.setSite(site);
			mbean.setTitle(bm.getLog().getTitle());
			mbean.setParentType(BookmarkBean.TYPE_DIARY);
			mbean.setParentId(((Integer)logids.get(new Integer(bm.getLog().getId()))).intValue());			
			new_ssn.save(mbean);
			System.out.println("BOOKMARK: " + bm.getId() + " -> " + mbean.getId());
		}
	}
	
	private static Hibernate old_hb;
	private static Hibernate new_hb;
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91对白在线观看九色| 亚洲欧洲99久久| 男人的天堂久久精品| 欧美日韩亚洲高清一区二区| 亚洲二区在线视频| 欧美一区二区久久久| 美女在线观看视频一区二区| 日韩视频免费直播| 国产一区在线看| 亚洲欧洲日产国码二区| 色综合视频在线观看| 久久国产尿小便嘘嘘| 久久奇米777| 成人av资源站| 亚洲一区二区三区四区五区黄| 7777精品伊人久久久大香线蕉完整版 | 欧美精品一区二区精品网| 久久精品国产精品亚洲综合| 国产欧美视频在线观看| 色狠狠桃花综合| 日韩1区2区3区| 国产亚洲午夜高清国产拍精品| 成人国产亚洲欧美成人综合网| 一区二区三区中文免费| 91精品国产综合久久久久| 国产福利一区在线| 亚洲影视在线观看| 精品国产91乱码一区二区三区 | 亚洲欧美日韩中文播放| 欧美一三区三区四区免费在线看 | 91精品国产入口| 粉嫩13p一区二区三区| 亚洲午夜三级在线| 久久久精品国产99久久精品芒果 | 久久午夜色播影院免费高清| 一本久久a久久免费精品不卡| 男女男精品视频| 日韩一区欧美一区| 91精品国产一区二区三区香蕉| 成人涩涩免费视频| 免费观看在线综合| 亚洲人成精品久久久久| 亚洲精品一线二线三线无人区| 91首页免费视频| 国产一区 二区 三区一级| 午夜不卡av免费| 国产精品福利一区二区三区| 欧美一区二区在线看| 91色综合久久久久婷婷| 国产乱子伦一区二区三区国色天香 | 韩国v欧美v日本v亚洲v| 亚洲影视在线播放| 综合精品久久久| 国产视频在线观看一区二区三区| 欧美一区二区在线看| 欧美性一级生活| 91丨porny丨户外露出| 成人免费看黄yyy456| 国产一二精品视频| 麻豆专区一区二区三区四区五区| 亚洲成人先锋电影| 一区二区三区四区蜜桃| 亚洲欧洲99久久| 国产精品污污网站在线观看| 久久综合久色欧美综合狠狠| 91精品国产91久久久久久最新毛片| 日本韩国欧美在线| 色综合亚洲欧洲| 97久久人人超碰| 成人精品一区二区三区中文字幕| 国产在线播精品第三| 国产美女娇喘av呻吟久久| 久久99久久99精品免视看婷婷 | 久久久久久久久伊人| 精品区一区二区| 精品乱人伦小说| 精品国产区一区| 2017欧美狠狠色| 国产午夜亚洲精品午夜鲁丝片| 久久亚洲精品国产精品紫薇| wwww国产精品欧美| 国产区在线观看成人精品| 国产人久久人人人人爽| 欧美高清一级片在线观看| 欧美激情综合在线| 国产精品久久久爽爽爽麻豆色哟哟| 日本一区二区三区在线不卡| 日本一区二区三区dvd视频在线| 国产欧美精品区一区二区三区| 国产视频在线观看一区二区三区| 欧美高清一级片在线观看| 最新国产精品久久精品| 一区二区三区四区视频精品免费 | 亚洲一区二区三区四区的| 偷窥少妇高潮呻吟av久久免费| 天堂一区二区在线| 老司机一区二区| 懂色中文一区二区在线播放| 成人一区二区三区中文字幕| 99re热这里只有精品免费视频| 在线一区二区视频| 91精品午夜视频| 国产三区在线成人av| 亚洲视频你懂的| 亚洲二区在线视频| 九色综合狠狠综合久久| 国产91丝袜在线18| 欧亚一区二区三区| 欧美电影免费观看高清完整版 | 视频一区中文字幕| 国产乱码精品1区2区3区| 91色九色蝌蚪| 91精品国产综合久久香蕉的特点| 久久毛片高清国产| 亚洲男人天堂一区| 日韩一区精品视频| 风间由美一区二区三区在线观看 | 一区二区在线观看视频| 美日韩一级片在线观看| 99综合电影在线视频| 777亚洲妇女| 亚洲国产成人在线| 奇米影视一区二区三区| av在线不卡网| 精品国产一区二区三区av性色 | 日韩中文欧美在线| 成人成人成人在线视频| 69堂成人精品免费视频| 中文字幕一区二区三区蜜月| 麻豆精品久久精品色综合| 91浏览器打开| 久久美女高清视频| 免费在线观看日韩欧美| 在线免费视频一区二区| 国产午夜精品一区二区三区视频| 亚洲国产视频网站| 成人白浆超碰人人人人| 久久尤物电影视频在线观看| 日韩精品欧美精品| 91视频国产观看| 国产欧美日韩精品一区| 精品一区二区三区久久| 欧美图区在线视频| 精品国产污污免费网站入口 | 美女爽到高潮91| 欧美日韩国产美女| 国产精品午夜春色av| 天堂va蜜桃一区二区三区 | 2020国产成人综合网| 午夜久久久久久久久| 95精品视频在线| 欧美激情艳妇裸体舞| 琪琪一区二区三区| 欧美一区二区在线看| 三级在线观看一区二区| 91在线一区二区三区| 中文字幕一区二区三区在线不卡 | 久久久综合网站| 久久99精品国产麻豆婷婷洗澡| 欧美午夜一区二区三区免费大片| 亚洲私人黄色宅男| 福利91精品一区二区三区| 国产欧美综合色| 亚洲自拍偷拍麻豆| 高清不卡一区二区| 国产精品视频第一区| 国产一区二区三区av电影| 精品伦理精品一区| 美女视频黄免费的久久 | 精品在线一区二区| 欧美一卡2卡3卡4卡| 天天色天天操综合| 这里只有精品电影| 亚洲一区二区美女| 欧美日韩精品电影| 亚洲线精品一区二区三区八戒| 欧美色视频一区| 综合欧美亚洲日本| 欧美日韩国产系列| 亚洲国产一区二区在线播放| 欧美主播一区二区三区| 亚洲丰满少妇videoshd| 在线不卡a资源高清| 久久爱www久久做| 欧美无人高清视频在线观看| 亚洲一二三区在线观看| 欧美午夜一区二区三区| 伊人性伊人情综合网| 6080国产精品一区二区| 免费黄网站欧美| 亚洲国产经典视频| 国产成人在线色| 中文字幕亚洲成人| 欧美日韩dvd在线观看| 午夜成人免费电影| 国产日韩影视精品| 99久久精品一区| 免费观看在线综合| 日韩一区二区影院| bt欧美亚洲午夜电影天堂|