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

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

?? insertidentityoperation.java

?? 采用 Java 編寫的數(shù)據(jù)庫系統(tǒng)單元測試程序。
?? JAVA
字號:
/*
 * InsertIdentityOperation.java
 *
 * The DbUnit Database Testing Framework
 * Copyright (C)2002-2004, DbUnit.org
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

package org.dbunit.ext.mssql;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import org.dbunit.DatabaseUnitException;
import org.dbunit.database.IDatabaseConnection;
import org.dbunit.database.DatabaseConfig;
import org.dbunit.dataset.*;
import org.dbunit.dataset.filter.IColumnFilter;
import org.dbunit.operation.AbstractOperation;
import org.dbunit.operation.CompositeOperation;
import org.dbunit.operation.DatabaseOperation;
import org.dbunit.operation.ExclusiveTransactionException;

import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * This class disable the MS SQL Server automatic identifier generation for
 * the execution of inserts.
 * <p>
 * If you are using the Microsoft driver (i.e.
 * <code>com.microsoft.jdbc.sqlserver.SQLServerDriver</code>), you'll need to
 * use the <code>SelectMethod=cursor</code> parameter in the JDBC connection
 * string. Your databaseUrl would look something like the following:
 * <p>
 * <code>jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb;SelectMethod=cursor</code>
 * <p>
 * Thanks to Jeremy Stein who has submitted multiple patches.
 *
 * @author Manuel Laflamme
 * @author Eric Pugh
 * @version $Revision: 558 $
 * @since Apr 9, 2002
 */
public class InsertIdentityOperation extends AbstractOperation
{

    /**
     * Logger for this class
     */
    private static final Logger logger = LoggerFactory.getLogger(InsertIdentityOperation.class);

    public static final String PROPERTY_IDENTITY_COLUMN_FILTER =
            "http://www.dbunit.org/properties/mssql/identityColumnFilter";

    public static final DatabaseOperation INSERT =
            new InsertIdentityOperation(DatabaseOperation.INSERT);

    public static final DatabaseOperation CLEAN_INSERT =
            new CompositeOperation(DatabaseOperation.DELETE_ALL,
                    new InsertIdentityOperation(DatabaseOperation.INSERT));

    public static final DatabaseOperation REFRESH =
            new InsertIdentityOperation(DatabaseOperation.REFRESH);

    private static final IColumnFilter DEFAULT_IDENTITY_FILTER = new IColumnFilter()
    {
        public boolean accept(String tableName, Column column)
        {
            logger.debug("accept(tableName=" + tableName + ", column=" + column + ") - start");

            return column.getSqlTypeName().endsWith("identity");
        }
    };


    private final DatabaseOperation _operation;

    /**
     * Creates a new InsertIdentityOperation object that decorates the
     * specified operation.
     */
    public InsertIdentityOperation(DatabaseOperation operation)
    {
        _operation = operation;
    }

    private boolean hasIdentityColumn(ITableMetaData metaData, IDatabaseConnection connection)
            throws DataSetException
    {
        logger.debug("hasIdentityColumn(metaData=" + metaData + ", connection=" + connection + ") - start");

        DatabaseConfig config = connection.getConfig();
        IColumnFilter identityFilter = (IColumnFilter)config.getProperty(
                PROPERTY_IDENTITY_COLUMN_FILTER);
        if (identityFilter == null)
        {
            identityFilter = DEFAULT_IDENTITY_FILTER;
        }

        // Verify if there is at least one identity column
        Column[] columns = metaData.getColumns();
        for (int i = 0; i < columns.length; i++)
        {
            if (identityFilter.accept(metaData.getTableName(), columns[i]))
            {
                return true;
            }
        }

        return false;
    }

    ////////////////////////////////////////////////////////////////////////////
    // DatabaseOperation class

    public void execute(IDatabaseConnection connection, IDataSet dataSet)
            throws DatabaseUnitException, SQLException
    {
        logger.debug("execute(connection=" + connection + ", dataSet) - start");

        Connection jdbcConnection = connection.getConnection();
        Statement statement = jdbcConnection.createStatement();

        try
        {
            IDataSet databaseDataSet = connection.createDataSet();
            

            // INSERT_IDENTITY need to be enabled/disabled inside the
            // same transaction
            if (jdbcConnection.getAutoCommit() == false)
            {
                throw new ExclusiveTransactionException();
            }
            jdbcConnection.setAutoCommit(false);

            // Execute decorated operation one table at a time
            ITableIterator iterator = dataSet.iterator();
            while(iterator.next())
            {
                ITable table = iterator.getTable();
                String tableName = table.getTableMetaData().getTableName();

                ITableMetaData metaData =
                        databaseDataSet.getTableMetaData(tableName);

                // enable identity insert
                boolean hasIdentityColumn = hasIdentityColumn(metaData, connection);

                if (hasIdentityColumn)
                {
                    StringBuffer sqlBuffer = new StringBuffer(128);
                    sqlBuffer.append("SET IDENTITY_INSERT ");
                    sqlBuffer.append(getQualifiedName(connection.getSchema(),
                            metaData.getTableName(), connection));
                    sqlBuffer.append(" ON");
                    statement.execute(sqlBuffer.toString());
                }

                try
                {
                    _operation.execute(connection, new DefaultDataSet(table));
                }
                finally
                {
                    // disable identity insert
                    if (hasIdentityColumn)
                    {
                        StringBuffer sqlBuffer = new StringBuffer(128);
                        sqlBuffer.append("SET IDENTITY_INSERT ");
                        sqlBuffer.append(getQualifiedName(connection.getSchema(),
                                metaData.getTableName(), connection));
                        sqlBuffer.append(" OFF");
                        statement.execute(sqlBuffer.toString());
                    }
                    jdbcConnection.commit();
                }
            }
        }
        finally
        {
            jdbcConnection.setAutoCommit(true);
            statement.close();
        }
    }
}






?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲色图欧洲色图| 国产成人高清在线| 国产综合色产在线精品| 国产精选一区二区三区| 99久久国产综合精品麻豆| 欧美日韩一区二区三区四区五区| 在线观看视频一区二区欧美日韩| 91精品国模一区二区三区| 久久久国产午夜精品| 亚洲欧洲日产国产综合网| 亚洲成av人片在线观看无码| 国产精品影视在线| 欧美日韩一区三区四区| 欧美国产1区2区| 精品伊人久久久久7777人| 91在线视频观看| 2023国产一二三区日本精品2022| 亚洲美女视频一区| 国产酒店精品激情| 日韩视频国产视频| 久久精品国产99| 99久久精品99国产精品| 精品sm捆绑视频| 美女一区二区在线观看| 欧美伊人久久大香线蕉综合69 | 91精品国产综合久久蜜臀 | 欧美在线观看一区二区| 亚洲欧洲精品一区二区三区 | 无码av中文一区二区三区桃花岛| aaa亚洲精品一二三区| 久久精品这里都是精品| 极品尤物av久久免费看| 精品三级在线观看| 精品一区二区在线免费观看| 91精选在线观看| 一区二区三区影院| 国内成人精品2018免费看| 色综合天天天天做夜夜夜夜做| 精品欧美一区二区久久| 亚洲国产美国国产综合一区二区| 成人午夜免费视频| 久久久欧美精品sm网站| 黄网站免费久久| 亚洲视频在线一区| 成人美女视频在线看| 欧美精品一区二| 国产专区欧美精品| 欧美一级在线视频| 爽好久久久欧美精品| 欧美一区二区三区精品| 肉丝袜脚交视频一区二区| 欧美日韩亚洲综合在线 | 美日韩黄色大片| 国产亚洲婷婷免费| 高清不卡在线观看av| 中文字幕高清不卡| 91在线国内视频| 一区二区免费在线| 欧美久久久一区| 免费在线成人网| 国产精品伦一区| 欧美日韩午夜在线视频| 日本少妇一区二区| 26uuu精品一区二区| 91网页版在线| 久久精品国产亚洲高清剧情介绍 | 欧美不卡123| 国产99精品国产| 一区二区三区中文在线观看| 欧美在线一二三四区| 寂寞少妇一区二区三区| 一区二区三区欧美视频| 精品理论电影在线观看| av电影一区二区| 日本视频一区二区三区| 久久久综合激的五月天| 欧美体内she精视频| 成人综合婷婷国产精品久久蜜臀| 亚洲线精品一区二区三区八戒| 成人三级伦理片| 国产精品美女久久久久久| 精品国产乱码91久久久久久网站| 成人黄色电影在线 | 高清视频一区二区| 亚洲综合男人的天堂| 久久亚洲精品小早川怜子| 91婷婷韩国欧美一区二区| 成人aa视频在线观看| 国产高清视频一区| 免费精品99久久国产综合精品| 亚洲在线中文字幕| 国产精品人人做人人爽人人添| 91精品午夜视频| 91精品国产色综合久久不卡蜜臀| 欧洲生活片亚洲生活在线观看| 成人毛片在线观看| 日韩国产欧美在线观看| 性感美女久久精品| 日本三级亚洲精品| 国产成a人无v码亚洲福利| 乱一区二区av| 国产在线一区观看| 国产美女精品人人做人人爽| 91丨porny丨中文| 国产成人av电影在线播放| 看电视剧不卡顿的网站| 蜜臀a∨国产成人精品| 天天影视涩香欲综合网| 琪琪久久久久日韩精品| 日本成人中文字幕| 国产电影一区二区三区| 成人免费高清在线| 欧美亚洲国产怡红院影院| www.日韩大片| 91精品国产丝袜白色高跟鞋| 欧美tk丨vk视频| 亚洲免费观看高清完整版在线观看 | 国产精品久久久久毛片软件| 亚洲欧洲制服丝袜| 秋霞成人午夜伦在线观看| 国产剧情一区二区三区| 91老师片黄在线观看| 欧美va亚洲va在线观看蝴蝶网| 中文字幕精品三区| 亚洲chinese男男1069| 精品在线一区二区三区| 91精彩视频在线| 久久久99精品久久| 亚洲午夜久久久久久久久电影院| 一区二区国产盗摄色噜噜| 秋霞国产午夜精品免费视频| av毛片久久久久**hd| 日韩美女主播在线视频一区二区三区| 亚洲国产精品99久久久久久久久| 天堂在线一区二区| 成人黄色电影在线| 精品国产91九色蝌蚪| 一区二区在线观看不卡| 91一区一区三区| 精品成a人在线观看| 亚洲综合在线第一页| 成人免费观看视频| 久久久蜜臀国产一区二区| 丝袜脚交一区二区| 欧美丰满嫩嫩电影| 亚洲国产综合91精品麻豆| 99精品欧美一区| 亚洲欧洲性图库| 国产一区福利在线| 欧美亚洲免费在线一区| 精品国精品自拍自在线| 夜夜操天天操亚洲| 日韩欧美一区二区久久婷婷| 成人激情图片网| 国产精品免费丝袜| 色素色在线综合| 亚洲国产综合视频在线观看| 欧美在线短视频| 亚洲国产欧美另类丝袜| 欧美日本韩国一区| 午夜精品免费在线| 久久亚洲综合色| 色婷婷精品大在线视频| 亚洲高清视频在线| 欧美一区二区三区日韩视频| 久久激五月天综合精品| 国产精品成人网| 99在线精品视频| 久久精品国产精品亚洲精品| 久久久无码精品亚洲日韩按摩| 国产成人av电影在线观看| 国产欧美一区二区精品性色| 国产成人av福利| 图片区小说区国产精品视频| 精品国产1区二区| 日本韩国一区二区三区| 国产凹凸在线观看一区二区| 亚洲地区一二三色| 1000精品久久久久久久久| 欧美成人一区二区| 91精品婷婷国产综合久久| 国产成人在线免费| 亚洲精品v日韩精品| 欧美大胆一级视频| 91成人在线免费观看| 天天色综合天天| 亚洲综合男人的天堂| 日韩亚洲欧美中文三级| www.综合网.com| 国产精品性做久久久久久| 美日韩黄色大片| 亚洲激情在线播放| 国产欧美在线观看一区| 欧美日韩一区二区三区在线看 | 国产精品国产精品国产专区不片| 91精品在线观看入口| 91麻豆精东视频| 国产精品一二三| 久久成人羞羞网站| 日本vs亚洲vs韩国一区三区二区|