浏览代码

autoConfigDialect 改为手动调用

James 1 年之前
父节点
当前提交
e5c10e444d
共有 1 个文件被更改,包括 49 次插入49 次删除
  1. 49 49
      src/main/java/com/jfinal/plugin/activerecord/ActiveRecordPlugin.java

+ 49 - 49
src/main/java/com/jfinal/plugin/activerecord/ActiveRecordPlugin.java

@@ -29,21 +29,21 @@ import com.jfinal.plugin.activerecord.sql.SqlKit;
 /**
  * ActiveRecord plugin.
  * <br>
- * ActiveRecord plugin not support mysql type year, you can use int instead of year. 
+ * ActiveRecord plugin not support mysql type year, you can use int instead of year.
  * Mysql error message for type year when insert a record: Data truncated for column 'xxx' at row 1
  */
 public class ActiveRecordPlugin implements IPlugin {
-	
+
 	protected TableBuilder tableBuilder = new TableBuilder();
-	
+
 	protected IDataSourceProvider dataSourceProvider = null;
 	protected Boolean devMode = null;
-	
+
 	protected Config config = null;
-	
+
 	protected volatile boolean isStarted = false;
 	protected List<Table> tableList = new ArrayList<Table>();
-	
+
 	public ActiveRecordPlugin(String configName, DataSource dataSource, int transactionLevel) {
 		if (StrKit.isBlank(configName)) {
 			throw new IllegalArgumentException("configName can not be blank");
@@ -53,19 +53,19 @@ public class ActiveRecordPlugin implements IPlugin {
 		}
 		this.config = new Config(configName, dataSource, transactionLevel);
 	}
-	
+
 	public ActiveRecordPlugin(DataSource dataSource) {
 		this(DbKit.MAIN_CONFIG_NAME, dataSource);
 	}
-	
+
 	public ActiveRecordPlugin(String configName, DataSource dataSource) {
 		this(configName, dataSource, DbKit.DEFAULT_TRANSACTION_LEVEL);
 	}
-	
+
 	public ActiveRecordPlugin(DataSource dataSource, int transactionLevel) {
 		this(DbKit.MAIN_CONFIG_NAME, dataSource, transactionLevel);
 	}
-	
+
 	public ActiveRecordPlugin(String configName, IDataSourceProvider dataSourceProvider, int transactionLevel) {
 		if (StrKit.isBlank(configName)) {
 			throw new IllegalArgumentException("configName can not be blank");
@@ -75,61 +75,61 @@ public class ActiveRecordPlugin implements IPlugin {
 		}
 		this.dataSourceProvider = dataSourceProvider;
 		this.config = new Config(configName, null, transactionLevel);
-		this.autoConfigDialect(dataSourceProvider.getJdbcUrl());
+		// this.autoConfigDialect(dataSourceProvider.getJdbcUrl());
 	}
-	
+
 	public ActiveRecordPlugin(IDataSourceProvider dataSourceProvider) {
 		this(DbKit.MAIN_CONFIG_NAME, dataSourceProvider);
 	}
-	
+
 	public ActiveRecordPlugin(String configName, IDataSourceProvider dataSourceProvider) {
 		this(configName, dataSourceProvider, DbKit.DEFAULT_TRANSACTION_LEVEL);
 	}
-	
+
 	public ActiveRecordPlugin(IDataSourceProvider dataSourceProvider, int transactionLevel) {
 		this(DbKit.MAIN_CONFIG_NAME, dataSourceProvider, transactionLevel);
 	}
-	
+
 	public ActiveRecordPlugin(Config config) {
 		if (config == null) {
 			throw new IllegalArgumentException("Config can not be null");
 		}
 		this.config = config;
 	}
-	
+
 	public ActiveRecordPlugin addMapping(String tableName, String primaryKey, Class<? extends Model<?>> modelClass) {
 		tableList.add(new Table(tableName, primaryKey, modelClass));
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin addMapping(String tableName, Class<? extends Model<?>> modelClass) {
 		tableList.add(new Table(tableName, modelClass));
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin addSqlTemplate(String sqlTemplate) {
 		config.sqlKit.addSqlTemplate(sqlTemplate);
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin addSqlTemplate(com.jfinal.template.source.ISource sqlTemplate) {
 		config.sqlKit.addSqlTemplate(sqlTemplate);
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin setBaseSqlTemplatePath(String baseSqlTemplatePath) {
 		config.sqlKit.setBaseSqlTemplatePath(baseSqlTemplatePath);
 		return this;
 	}
-	
+
 	public SqlKit getSqlKit() {
 		return config.sqlKit;
 	}
-	
+
 	public com.jfinal.template.Engine getEngine() {
 		return getSqlKit().getEngine();
 	}
-	
+
 	/**
 	 * Set transaction level define in java.sql.Connection
 	 * @param transactionLevel only be 0, 1, 2, 4, 8
@@ -138,7 +138,7 @@ public class ActiveRecordPlugin implements IPlugin {
 		config.setTransactionLevel(transactionLevel);
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin setCache(ICache cache) {
 		if (cache == null) {
 			throw new IllegalArgumentException("cache can not be null");
@@ -146,22 +146,22 @@ public class ActiveRecordPlugin implements IPlugin {
 		config.cache = cache;
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin setShowSql(boolean showSql) {
 		config.showSql = showSql;
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin setDevMode(boolean devMode) {
 		this.devMode = devMode;
 		config.setDevMode(devMode);
 		return this;
 	}
-	
+
 	public Boolean getDevMode() {
 		return devMode;
 	}
-	
+
 	public ActiveRecordPlugin setDialect(Dialect dialect) {
 		if (dialect == null) {
 			throw new IllegalArgumentException("dialect can not be null");
@@ -173,7 +173,7 @@ public class ActiveRecordPlugin implements IPlugin {
 		}
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin setContainerFactory(IContainerFactory containerFactory) {
 		if (containerFactory == null) {
 			throw new IllegalArgumentException("containerFactory can not be null");
@@ -181,7 +181,7 @@ public class ActiveRecordPlugin implements IPlugin {
 		config.containerFactory = containerFactory;
 		return this;
 	}
-	
+
 	public ActiveRecordPlugin setDbProFactory(IDbProFactory dbProFactory) {
 		if (dbProFactory == null) {
 			throw new IllegalArgumentException("dbProFactory can not be null");
@@ -189,14 +189,14 @@ public class ActiveRecordPlugin implements IPlugin {
 		config.dbProFactory = dbProFactory;
 		return this;
 	}
-	
+
 	/**
 	 * 当使用 create table 语句创建用于开发使用的数据表副本时,假如create table 中使用的
 	 * 复合主键次序不同,那么MappingKitGeneretor 反射生成的复合主键次序也会不同。
-	 * 
+	 *
 	 * 而程序中类似于 model.deleteById(id1, id2) 方法中复合主键次序与需要与映射时的次序
 	 * 保持一致,可以在MappingKit 映射完成以后通过调用此方法再次强制指定复合主键次序
-	 * 
+	 *
 	 * <pre>
 	 * Example:
 	 * ActiveRecrodPlugin arp = new ActiveRecordPlugin(...);
@@ -212,7 +212,7 @@ public class ActiveRecordPlugin implements IPlugin {
 			}
 		}
 	}
-	
+
 	public boolean start() {
 		if (isStarted) {
 			return true;
@@ -223,28 +223,28 @@ public class ActiveRecordPlugin implements IPlugin {
 		if (config.dataSource == null) {
 			throw new RuntimeException("ActiveRecord start error: ActiveRecordPlugin need DataSource or DataSourceProvider");
 		}
-		
+
 		config.sqlKit.parseSqlTemplate();
-		
+
 		tableBuilder.build(tableList, config);
 		DbKit.addConfig(config);
 		isStarted = true;
 		return true;
 	}
-	
+
 	public boolean stop() {
 		DbKit.removeConfig(config.getName());
 		isStarted = false;
 		return true;
 	}
-	
+
 	/**
 	 * 用于分布式场景,当某个分布式节点只需要用 Model 承载和传输数据,而不需要实际操作数据库时
 	 * 调用本方法可保障 IContainerFactory、Dialect、ICache 的一致性
-	 * 
+	 *
 	 * 本用法更加适用于 Generator 生成的继承自 base model的 Model,更加便于传统第三方工具对
 	 * 带有 getter、setter 的 model 进行各种处理
-	 * 
+	 *
 	 * <pre>
 	 * 警告:Dialect、IContainerFactory、ICache 三者一定要与集群中其它节点保持一致,
 	 *     以免程序出现不一致行为
@@ -267,7 +267,7 @@ public class ActiveRecordPlugin implements IPlugin {
 		arp.start();
 		DbKit.brokenConfig = arp.config;
 	}
-	
+
 	/**
 	 * 分布式场景下指定 IContainerFactory,并默认使用 MysqlDialect、EhCache
 	 * @see #useAsDataTransfer(Dialect, IContainerFactory, ICache)
@@ -275,7 +275,7 @@ public class ActiveRecordPlugin implements IPlugin {
 	public static void useAsDataTransfer(IContainerFactory containerFactory) {
 		useAsDataTransfer(new com.jfinal.plugin.activerecord.dialect.MysqlDialect(), containerFactory, new com.jfinal.plugin.activerecord.cache.EhCache());
 	}
-	
+
 	/**
 	 * 分布式场景下指定 Dialect、IContainerFactory,并默认使用 EhCache
 	 * @see #useAsDataTransfer(Dialect, IContainerFactory, ICache)
@@ -283,7 +283,7 @@ public class ActiveRecordPlugin implements IPlugin {
 	public static void useAsDataTransfer(Dialect dialect, IContainerFactory containerFactory) {
 		useAsDataTransfer(dialect, containerFactory, new com.jfinal.plugin.activerecord.cache.EhCache());
 	}
-	
+
 	/**
 	 * 分布式场景下指定 Dialect、 并默认使用 IContainerFactory.defaultContainerFactory、EhCache
 	 * @see #useAsDataTransfer(Dialect, IContainerFactory, ICache)
@@ -291,7 +291,7 @@ public class ActiveRecordPlugin implements IPlugin {
 	public static void useAsDataTransfer(Dialect dialect) {
 		useAsDataTransfer(dialect, IContainerFactory.defaultContainerFactory, new com.jfinal.plugin.activerecord.cache.EhCache());
 	}
-	
+
 	/**
 	 * 分布式场景下默认使用 MysqlDialect、 IContainerFactory.defaultContainerFactory、EhCache
 	 * @see #useAsDataTransfer(Dialect, IContainerFactory, ICache)
@@ -299,18 +299,18 @@ public class ActiveRecordPlugin implements IPlugin {
 	public static void useAsDataTransfer() {
 		useAsDataTransfer(new com.jfinal.plugin.activerecord.dialect.MysqlDialect(), IContainerFactory.defaultContainerFactory, new com.jfinal.plugin.activerecord.cache.EhCache());
 	}
-	
+
 	public Config getConfig() {
 		return config;
 	}
-	
+
 	/**
 	 * 一般用于配置 TableBuilder 内的 JavaType
 	 * <pre>
 	 * 例如:
 	 *    ActiveRecordPlugin arp = ...;
 	 *    JavaType jt = arp.getTableBuilder().getJavaType();
-	 *    
+	 *
 	 *    jt.addType(org.postgresql.geometric.PGpoint.class);
 	 *    jt.addType(org.postgresql.geometric.PGbox.class);
 	 *    jt.addType(org.postgresql.geometric.PGcircle.class);
@@ -323,7 +323,7 @@ public class ActiveRecordPlugin implements IPlugin {
 	public TableBuilder getTableBuilder() {
 		return tableBuilder;
 	}
-	
+
 	/**
 	 * 可用于切换 TableBuilder 实现类
 	 */
@@ -332,7 +332,7 @@ public class ActiveRecordPlugin implements IPlugin {
 		return this;
 	}
 
-	private void autoConfigDialect(String jdbcUrl) {
+	public void autoConfigDialect(String jdbcUrl) {
 		if (jdbcUrl.startsWith("jdbc:") && jdbcUrl.substring("jdbc:".length()).contains(":")) {
 			String dialect = jdbcUrl.substring("jdbc:".length(), jdbcUrl.indexOf(":", "jdbc:".length())).toLowerCase();
 			switch (dialect) {