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

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

?? checksumhistorydao.java

?? DSPACE的源碼 dspace-1.4-source
?? JAVA
字號:
package org.dspace.checker;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import java.sql.Timestamp;import java.util.Date;import java.util.Iterator;import java.util.Map;import org.apache.log4j.Logger;import org.dspace.storage.rdbms.DatabaseManager;/** * <p> * This is the data access for the checksum history information. All * update,insert and delete database operations should go through this class for * checksum history operations. * </p> *  * @author Jim Downing * @author Grace Carpenter * @author Nathan Sarr *  *  */public class ChecksumHistoryDAO extends DAOSupport{    /**     * Query that selects bitstream IDs from most_recent_checksum table that are     * not yet in the checksum_history table, and inserts them into     * checksum_history.     */    private static final String INSERT_MISSING_HISTORY_BITSTREAMS = "insert into checksum_history ( "            + "bitstream_id, process_start_date, "            + "process_end_date, checksum_expected, "            + "checksum_calculated, result ) "            + "select most_recent_checksum.bitstream_id, "            + "most_recent_checksum.last_process_start_date, "            + "most_recent_checksum.last_process_end_date, "            + "most_recent_checksum.expected_checksum, most_recent_checksum.expected_checksum, "            + "CASE WHEN bitstream.deleted = true THEN 'BITSTREAM_MARKED_DELETED' else 'CHECKSUM_MATCH' END "            + "from most_recent_checksum, bitstream where "            + "not exists( select 'x' from checksum_history where "            + "most_recent_checksum.bitstream_id = checksum_history.bitstream_id ) "            + "and most_recent_checksum.bitstream_id = bitstream.bitstream_id;";    /** Query that inserts results of recent check into the history table. */    private static final String INSERT_HISTORY = "insert into checksum_history (  bitstream_id, process_start_date, "            + " process_end_date, checksum_expected, checksum_calculated, result ) "            + " values ( ?, ?, ?, ?, ?, ?);";    /**     * Deletes from the most_recent_checksum where the bitstream id is found     */    private static final String DELETE_BITSTREAM_HISTORY = "Delete from checksum_history "            + "where bitstream_id = ?";    /**     * Logger for the checksum history DAO.     */    private static final Logger LOG = Logger            .getLogger(ChecksumHistoryDAO.class);    /**     * Inserts results of checksum check into checksum_history table for a given     * bitstream.     *      * @param info     *            the BitstreamInfo representing a checksum check.     *      * @throws IllegalArgumentException     *             if the <code>BitstreamInfo</code> is null.     */    public void insertHistory(BitstreamInfo info)    {        if (info == null)        {            throw new IllegalArgumentException(                    "BitstreamInfo parameter may not be null");        }        Connection conn = null;        PreparedStatement stmt = null;        try        {            conn = DatabaseManager.getConnection();            stmt = conn.prepareStatement(INSERT_HISTORY);            stmt.setInt(1, info.getBitstreamId());            stmt.setTimestamp(2, new java.sql.Timestamp(info                    .getProcessStartDate().getTime()));            stmt.setTimestamp(3, new java.sql.Timestamp(info                    .getProcessEndDate().getTime()));            stmt.setString(4, info.getStoredChecksum());            stmt.setString(5, info.getCalculatedChecksum());            stmt.setString(6, info.getChecksumCheckResult());            stmt.executeUpdate();            conn.commit();        }        catch (SQLException e)        {            LOG.error("Problem updating checksum row. " + e.getMessage(), e);            throw new RuntimeException("Problem updating checksum row. "                    + e.getMessage(), e);        }        finally        {            cleanup(stmt, conn);        }    }    /**     * Deletes the bitstream from the bitstream_history table if it exist.     *      * @param id     *            the bitstream id.     *      * @return number of records deleted     */    protected int deleteHistoryForBitstreamInfo(int id, Connection conn)    {        PreparedStatement stmt = null;        int numDeleted = 0;        try        {            conn = DatabaseManager.getConnection();            stmt = conn.prepareStatement(DELETE_BITSTREAM_HISTORY);            stmt.setInt(1, id);            numDeleted = stmt.executeUpdate();            conn.commit();        }        catch (SQLException e)        {            LOG.error("Problem with inserting missing bitstream. "                    + e.getMessage(), e);            throw new RuntimeException("Problem inserting missing bitstream. "                    + e.getMessage(), e);        }        finally        {            cleanup(stmt, conn);        }        return numDeleted;    }    /**     * @param conn     */    protected void updateMissingBitstreams(Connection conn) throws SQLException    {        PreparedStatement stmt = null;        try        {            stmt = conn.prepareStatement(INSERT_MISSING_HISTORY_BITSTREAMS);            stmt.executeUpdate();        }        catch (SQLException e)        {            LOG.error("Problem updating missing history. " + e.getMessage(), e);            throw new RuntimeException("Problem updating missing history. "                    + e.getMessage(), e);        }        finally        {            cleanup(stmt);        }    }    /**     * Delete the history records from the database.     *      * @param retentionDate     *            any records older than this data are deleted.     * @param result     *            result code records must have for them to be deleted.     * @param conn     *            database connection.     * @return number of records deleted.     * @throws SQLException     *             if database error occurs.     */    protected int deleteHistoryByDateAndCode(Date retentionDate, String result,            Connection conn) throws SQLException    {        PreparedStatement update = null;        try        {            update = conn                    .prepareStatement("DELETE FROM checksum_history WHERE process_end_date<? AND result=?");            update.setTimestamp(1, new Timestamp(retentionDate.getTime()));            update.setString(2, result);            return update.executeUpdate();        }        finally        {            cleanup(update);        }    }    /**     * Prune the history records from the database.     *      * @param interests     *            set of results and the duration of time before they are     *            removed from the database     *      * @return number of bitstreams deleted     */    public int prune(Map interests)    {        Connection conn = null;        try        {            conn = DatabaseManager.getConnection();            long now = System.currentTimeMillis();            int count = 0;            for (Iterator iter = interests.keySet().iterator(); iter.hasNext();)            {                String result = (String) iter.next();                Long dur = (Long) interests.get(result);                count += deleteHistoryByDateAndCode(new Date(now                        - dur.longValue()), result, conn);                conn.commit();            }            return count;        }        catch (SQLException e)        {            LOG.error("Problem pruning results: " + e.getMessage(), e);            throw new RuntimeException("Problem pruning results: "                    + e.getMessage(), e);        }        finally        {            DatabaseManager.freeConnection(conn);        }    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕精品在线不卡| 日韩一区二区精品在线观看| 日本不卡一二三| 依依成人精品视频| 国产精品久久一级| 亚洲国产精品高清| 欧美激情在线看| 欧美激情资源网| 国产精品欧美精品| 成人免费小视频| 国产精品免费网站在线观看| 久久久久久久久久久电影| 久久一区二区视频| 国产免费久久精品| 中文字幕五月欧美| 亚洲精品国产a| 亚洲国产成人高清精品| 亚洲bt欧美bt精品777| 日韩精品每日更新| 国内久久婷婷综合| 成人精品高清在线| 在线视频国内一区二区| 欧美欧美午夜aⅴ在线观看| 欧美日产在线观看| 欧美不卡一二三| 国产欧美精品一区二区三区四区| 欧美国产一区二区在线观看| 亚洲天堂中文字幕| 午夜电影一区二区三区| 麻豆国产欧美日韩综合精品二区| 国产精品一级在线| av福利精品导航| 91在线播放网址| 91精品免费观看| 国产亚洲婷婷免费| 亚洲最大的成人av| 看电影不卡的网站| 99久久国产综合精品麻豆| 欧美系列在线观看| 久久久亚洲精华液精华液精华液| 中文字幕一区在线| 热久久国产精品| 成人免费不卡视频| 制服丝袜在线91| 中文字幕在线不卡| 久久精品国产99久久6| 97精品电影院| 久久免费美女视频| 日韩激情一区二区| 91一区一区三区| 精品国产伦一区二区三区免费| 亚洲人成网站精品片在线观看| 性久久久久久久久| 99在线热播精品免费| 日韩视频国产视频| 亚洲国产精品一区二区www在线| 国内精品伊人久久久久av一坑| 91福利在线导航| 国产精品美女久久久久久久| 青青青爽久久午夜综合久久午夜| 99久久精品费精品国产一区二区| 日韩一区二区精品葵司在线 | 成人黄色软件下载| 91精品国产色综合久久久蜜香臀| **欧美大码日韩| 国产精品1024| 欧美mv和日韩mv国产网站| 亚洲成人免费电影| 在线影视一区二区三区| 中文字幕人成不卡一区| 国产一二三精品| 精品久久久久久久久久久久包黑料| 一区二区日韩电影| 99这里只有精品| 中文字幕永久在线不卡| 成人免费av网站| 欧美国产一区在线| 成人污污视频在线观看| 欧美激情在线一区二区| 国产成人精品影院| 欧美国产精品劲爆| www.亚洲精品| 国产精品久久久久久久久免费樱桃| 韩国精品免费视频| 久久久精品日韩欧美| 精品一区二区综合| 久久久噜噜噜久噜久久综合| 久久精品国产99| 国产视频一区二区在线观看| 国产91精品久久久久久久网曝门 | 久久91精品国产91久久小草| 日韩一卡二卡三卡国产欧美| 奇米在线7777在线精品| 欧美成人a∨高清免费观看| 久久精品噜噜噜成人88aⅴ| 精品国产伦一区二区三区免费 | 国产一区二区看久久| 久久综合狠狠综合久久综合88 | 久久久精品免费观看| 国产伦精品一区二区三区免费迷| 久久九九影视网| 成人精品小蝌蚪| 一个色妞综合视频在线观看| 欧美美女黄视频| 国产在线视频精品一区| 欧美激情一区二区在线| 91黄色在线观看| 捆绑调教一区二区三区| 国产丝袜美腿一区二区三区| 972aa.com艺术欧美| 亚洲v中文字幕| 国产亚洲福利社区一区| 欧美性xxxxx极品少妇| 久久精品国产亚洲aⅴ| 国产精品国产自产拍高清av| 欧美日韩在线亚洲一区蜜芽| 激情久久五月天| 亚洲人吸女人奶水| 日韩欧美一级二级| 色综合天天综合色综合av| 青娱乐精品在线视频| 久久精品欧美一区二区三区不卡 | 亚洲精品国产精品乱码不99| 日韩一级片在线播放| av不卡在线播放| 美女高潮久久久| 亚洲天堂2016| 久久久综合九色合综国产精品| 日本韩国精品一区二区在线观看| 麻豆精品久久久| 亚洲最大的成人av| 国产精品美女一区二区三区 | 精品在线一区二区| 亚洲一二三四区| 国产精品久久二区二区| 日韩一区二区三区电影| 欧美性色黄大片| 99re66热这里只有精品3直播| 久久精品国产一区二区| 五月天视频一区| 日韩毛片在线免费观看| 国产亚洲精品久| 精品国产免费久久| 91精品国产福利| 欧美日韩国产影片| 欧洲色大大久久| 色婷婷久久久综合中文字幕| 丁香婷婷综合激情五月色| 国产在线国偷精品产拍免费yy| 亚洲6080在线| 亚洲超碰精品一区二区| 亚洲永久免费视频| 一区二区成人在线视频| 亚洲欧美日韩在线| 亚洲美女少妇撒尿| 亚洲啪啪综合av一区二区三区| 国产欧美久久久精品影院| 国产亚洲人成网站| 亚洲国产精品激情在线观看| 日本一区二区三区dvd视频在线 | 久久久久高清精品| 国产亚洲综合性久久久影院| 亚洲精品一区二区三区四区高清| 日韩午夜电影在线观看| 欧美刺激午夜性久久久久久久| 日韩欧美区一区二| 精品国产人成亚洲区| 国产日韩欧美亚洲| 最新日韩在线视频| 亚洲综合在线视频| 男女激情视频一区| 韩国一区二区视频| 成人黄色片在线观看| 97成人超碰视| 91 com成人网| 久久综合色鬼综合色| 欧美激情在线观看视频免费| 综合久久给合久久狠狠狠97色| 夜夜操天天操亚洲| 日本色综合中文字幕| 久久精品99久久久| 波多野结衣中文一区| 91成人在线观看喷潮| 欧美一区二区在线视频| 国产目拍亚洲精品99久久精品| 自拍偷拍欧美激情| 美女诱惑一区二区| 成人性色生活片| 欧美日韩在线播放三区| 久久综合狠狠综合久久综合88| 国产精品久久久久久妇女6080| 亚洲午夜久久久| 狠狠色丁香婷婷综合| 色呦呦网站一区| 精品国产亚洲在线| 18欧美亚洲精品| 精品在线一区二区三区| 91久久精品网| 国产亚洲一区字幕| 午夜免费久久看|