dbunit mysql bug no_dbunit经典的NoSuchColumnException解决之道

package com.ridge.test.unitils.ext;

import org.dbunit.database.DatabaseConfig;

import org.dbunit.database.DefaultMetadataHandler;

import org.dbunit.dataset.DataSetException;

import org.dbunit.dataset.IDataSet;

import org.dbunit.dataset.datatype.IDataTypeFactory;

import org.dbunit.dataset.filter.ITableFilterSimple;

import org.dbunit.ext.db2.Db2DataTypeFactory;

import org.dbunit.ext.db2.Db2MetadataHandler;

import org.dbunit.ext.mysql.MySqlDataTypeFactory;

import org.dbunit.ext.mysql.MySqlMetadataHandler;

import org.unitils.core.UnitilsException;

import org.unitils.core.dbsupport.DbSupport;

import org.unitils.core.dbsupport.DefaultSQLHandler;

import org.unitils.core.dbsupport.SQLHandler;

import org.unitils.dbunit.DbUnitModule;

import org.unitils.dbunit.util.DbUnitDatabaseConnection;

import javax.sql.DataSource;

import static org.dbunit.database.DatabaseConfig.FEATURE_BATCHED_STATEMENTS;

import static org.dbunit.database.DatabaseConfig.PROPERTY_DATATYPE_FACTORY;

import static org.dbunit.database.DatabaseConfig.PROPERTY_ESCAPE_PATTERN;

import static org.unitils.core.dbsupport.DbSupportFactory.getDbSupport;

import static org.unitils.core.util.ConfigUtils.getInstanceOf;

/**

* @author : chenxh(quickselect@163.com)

* @date: 13-10-9

*/

public class MyDbunitModule extends DbUnitModule {

protected DbUnitDatabaseConnection createDbUnitConnection(String schemaName) {

// A DbSupport instance is fetched in order to get the schema name in correct case

DataSource dataSource = getDatabaseModule().getDataSourceAndActivateTransactionIfNeeded();

SQLHandler sqlHandler = new DefaultSQLHandler(dataSource);

DbSupport dbSupport = getDbSupport(configuration, sqlHandler, schemaName);

// Create connection

DbUnitDatabaseConnection connection = new DbUnitDatabaseConnection(dataSource, dbSupport.getSchemaName());

DatabaseConfig config = connection.getConfig();

// Make sure that dbunit's correct IDataTypeFactory, that handles dbms specific data type issues, is used

IDataTypeFactory dataTypeFactory = getInstanceOf(IDataTypeFactory.class, configuration, dbSupport.getDatabaseDialect());

config.setProperty(PROPERTY_DATATYPE_FACTORY, dataTypeFactory);

// Make sure that table and column names are escaped using the dbms-specific identifier quote string

if (dbSupport.getIdentifierQuoteString() != null)

config.setProperty(PROPERTY_ESCAPE_PATTERN, dbSupport.getIdentifierQuoteString() + '?' + dbSupport.getIdentifierQuoteString());

// Make sure that batched statements are used to insert the data into the database

config.setProperty(FEATURE_BATCHED_STATEMENTS, "true");

// Make sure that Oracle's recycled tables (BIN$) are ignored (value is used to ensure dbunit-2.2 compliancy)

config.setProperty("http://www.dbunit.org/features/skipOracleRecycleBinTables", "true");

//注意这儿:根据不同的数据库(unitils的database.dialect配置参数)为dbunit

//指定使用不同的IMetadataHandler实现(其它数据库都可以用默认的,还有一个Netezza也是特别的,这里忽略了)

if("db2".equalsIgnoreCase(configuration.getProperty("database.dialect"))){

config.setProperty(DatabaseConfig.PROPERTY_DATATYPE_FACTORY,

new Db2DataTypeFactory());

//由于dbunit自身提供的Db2MetadataHandler有BUG,所以这里使用自己写的

//MyDb2MetadataHandler,源码在后面了。

config.setProperty(DatabaseConfig.PROPERTY_METADATA_HANDLER,

new MyDb2MetadataHandler());

}else if("mysql".equalsIgnoreCase(configuration.getProperty("database.dialect"))){

config.setProperty(DatabaseConfig.PROPERTY_DATATYPE_FACTORY,

new MySqlDataTypeFactory());

config.setProperty(DatabaseConfig.PROPERTY_METADATA_HANDLER,

new MySqlMetadataHandler());

}

return connection;

}

}

### 解决 Mac 上 GitHub 客户端无法打开的问题 对于 Mac 用户遇到的 GitHub 客户端无法启动的情况,可能由多种因素引起。通常可以从以下几个方面排查并解决问题: #### 1. 更新应用程序 确保使用的 GitHub Desktop 版本是最新的。旧版本可能存在兼容性问题或是已知漏洞,更新到最新版可以修复这些问题。 ```bash # 打开终端执行命令来检查是否有可用更新 sudo softwareupdate -l ``` 如果通过应用商店安装,则前往 App Store 查看是否存在待更新项[^1]。 #### 2. 清除缓存数据 有时本地存储的数据可能导致程序运行异常。尝试清除 GitHub Desktop 的偏好设置文件夹以重置其状态。 - 关闭所有正在运行的应用实例。 - 使用 Finder 或者 Terminal 导航至 `~/Library/Application Support/GitHub Desktop` 并删除该目录下的内容。 请注意备份重要信息后再操作此步骤[^2]。 #### 3. 检查依赖服务的状态 确认计算机上的 Git 和其他关联工具正常工作。可以通过命令行测试基本功能是否完好无损。 ```bash git --version ssh -T git@github.com ``` 上述指令用于验证 Git 是否正确安装以及 SSH 连接能否成功建立[^3]。 #### 4. 日志分析 当常规方法未能奏效时,查阅日志记录有助于发现潜在错误原因。GitHub Desktop 存储的日志位于用户的库副本路径下 `.git/github-desktop.log` 文件内;也可以利用 macOS 自带控制台应用查看更详细的系统级消息[^4]。 #### 5. 卸载重装软件包 作为最后手段,在完全移除现有安装之后再重新下载官方发布的稳定版本进行全新部署不失为一种有效方式。记得提前导出必要的配置和个人资料以免丢失[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值