add field

This commit is contained in:
Looly 2020-09-15 12:54:31 +08:00
parent 13431497ae
commit 37b051a46c
13 changed files with 417 additions and 71 deletions

View File

@ -12,6 +12,8 @@
* 【core 】 扩充Console功能支持可变参数issue#1077@Github
* 【crypto 】 增加ECKeyUtilissue#I1UOF5@Gitee
* 【core 】 增加TransXXXissue#I1TU1Y@Gitee
* 【core 】 增加Generator
* 【db 】 Column增加是否主键、保留位数等字段
### Bug修复
* 【core 】 修复Dict.of错误issue#I1UUO5@Gitee

View File

@ -1005,20 +1005,14 @@ public class FileUtil extends PathUtil {
}
/**
* 修改文件或目录的文件名不变更路径只是简单修改文件名<br>
* 重命名有两种模式<br>
* 1isRetainExt为true时保留原扩展名
* 修改文件或目录的文件名不变更路径只是简单修改文件名不保留扩展名<br>
*
* <pre>
* FileUtil.rename(file, "aaa", true) xx/xx.png =xx/aaa.png
* </pre>
*
* <pre>
* FileUtil.rename(file, "aaa.jpg", false) xx/xx.png =xx/aaa.jpg
* FileUtil.rename(file, "aaa.png", true) xx/xx.png =xx/aaa.png
* </pre>
*
* @param file 被修改的文件
* @param newName 新的文件名包括扩展名
* @param newName 新的文件名如需扩展名需自行在此参数加上原文件名的扩展名不会被保留
* @param isOverride 是否覆盖目标文件
* @return 目标文件
* @since 5.3.6
@ -1035,6 +1029,7 @@ public class FileUtil extends PathUtil {
* <pre>
* FileUtil.rename(file, "aaa", true) xx/xx.png =xx/aaa.png
* </pre>
*
* <p>
* 2isRetainExt为false时不保留原扩展名需要在newName中
*

View File

@ -0,0 +1,18 @@
package cn.hutool.core.lang.generator;
/**
* 生成器泛型接口<br>
* 通过实现此接口可以自定义生成对象的策略
*
* @param <T> 生成对象类型
* @since 5.4.3
*/
public interface Generator<T> {
/**
* 生成新的对象
*
* @return 新的对象
*/
T next();
}

View File

@ -0,0 +1,28 @@
package cn.hutool.core.lang.generator;
import cn.hutool.core.util.ReflectUtil;
/**
* 对象生成器通过指定对象的Class类型调用next方法时生成新的对象
*
* @param <T> 对象类型
* @author looly
* @since 5.4.3
*/
public class ObjectGenerator<T> implements Generator<T> {
private final Class<T> clazz;
/**
* 构造
* @param clazz 对象类型
*/
public ObjectGenerator(Class<T> clazz) {
this.clazz = clazz;
}
@Override
public T next() {
return ReflectUtil.newInstanceIfPossible(this.clazz);
}
}

View File

@ -0,0 +1,16 @@
package cn.hutool.core.lang.generator;
import cn.hutool.core.lang.ObjectId;
/**
* ObjectId生成器
*
* @author looly
* @since 5.4.3
*/
public class ObjectIdGenerator implements Generator<String> {
@Override
public String next() {
return ObjectId.next();
}
}

View File

@ -0,0 +1,38 @@
package cn.hutool.core.lang.generator;
import cn.hutool.core.lang.Snowflake;
/**
* Snowflake生成器<br>
* 注意默认此生成器必须单例使用否则会有重复<br>
* 默认构造的终端ID和数据中心ID都为0不适用于分布式环境
*
* @author looly
* @since 5.4.3
*/
public class SnowflakeGenerator implements Generator<Long> {
private final Snowflake snowflake;
/**
* 构造
*/
public SnowflakeGenerator() {
this(0, 0);
}
/**
* 构造
*
* @param workerId 终端ID
* @param dataCenterId 数据中心ID
*/
public SnowflakeGenerator(long workerId, long dataCenterId) {
snowflake = new Snowflake(workerId, dataCenterId);
}
@Override
public Long next() {
return this.snowflake.nextId();
}
}

View File

@ -0,0 +1,16 @@
package cn.hutool.core.lang.generator;
import cn.hutool.core.util.IdUtil;
/**
* UUID生成器
*
* @author looly
* @since 5.4.3
*/
public class UUIDGenerator implements Generator<String> {
@Override
public String next() {
return IdUtil.fastUUID();
}
}

View File

@ -0,0 +1,7 @@
/**
* 提供生成器接口及相关封装
*
* @author looly
*
*/
package cn.hutool.core.lang.generator;

View File

@ -1,10 +1,9 @@
package cn.hutool.core.date;
import cn.hutool.core.date.BetweenFormater.Level;
import org.junit.Assert;
import org.junit.Test;
import cn.hutool.core.date.BetweenFormater.Level;
public class BetweenFormaterTest {
@Test

View File

@ -1,6 +1,6 @@
package cn.hutool.db.dialect.impl;
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.collection.ListUtil;
import cn.hutool.core.lang.Assert;
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.util.StrUtil;
@ -10,7 +10,11 @@ import cn.hutool.db.Page;
import cn.hutool.db.StatementUtil;
import cn.hutool.db.dialect.Dialect;
import cn.hutool.db.dialect.DialectName;
import cn.hutool.db.sql.*;
import cn.hutool.db.sql.Condition;
import cn.hutool.db.sql.LogicalOperator;
import cn.hutool.db.sql.Query;
import cn.hutool.db.sql.SqlBuilder;
import cn.hutool.db.sql.Wrapper;
import java.sql.Connection;
import java.sql.PreparedStatement;
@ -129,7 +133,7 @@ public class AnsiSqlDialect implements Dialect {
@Override
public PreparedStatement psForCount(Connection conn, Query query) throws SQLException {
query.setFields(CollectionUtil.newArrayList("count(1)"));
query.setFields(ListUtil.toList("count(1)"));
return psForFind(conn, query);
}

View File

@ -1,51 +1,88 @@
package cn.hutool.db.meta;
import cn.hutool.core.util.BooleanUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.db.DbRuntimeException;
import java.io.Serializable;
import java.sql.ResultSet;
import java.sql.SQLException;
import cn.hutool.core.util.StrUtil;
import cn.hutool.db.DbRuntimeException;
/**
* 数据库表的列信息
*
* @author loolly
*
* @author loolly
*/
public class Column implements Serializable, Cloneable {
private static final long serialVersionUID = 577527740359719367L;
// ----------------------------------------------------- Fields start
/** 表名 */
/**
* 表名
*/
private String tableName;
/** 列名 */
/**
* 列名
*/
private String name;
/** 类型对应java.sql.Types中的类型 */
/**
* 类型对应java.sql.Types中的类型
*/
private int type;
/** 类型名称 */
/**
* 类型名称
*/
private String typeName;
/** 大小或数据长度 */
/**
* 大小或数据长度
*/
private int size;
/** 是否为可空 */
private Integer digit;
/**
* 是否为可空
*/
private boolean isNullable;
/** 注释 */
/**
* 注释
*/
private String comment;
/**
* 是否自增
*/
private boolean autoIncrement;
/**
* 是否为主键
*/
private boolean isPk;
// ----------------------------------------------------- Fields end
/**
* 创建列对象
*
* @param tableName 表名
*
* @param tableName 表名
* @param columnMetaRs 列元信息的ResultSet
* @return 列对象
* @deprecated 请使用 {@link #create(Table, ResultSet)}
*/
public static Column create(String tableName, ResultSet columnMetaRs) {
return new Column(tableName, columnMetaRs);
}
/**
* 创建列对象
*
* @param columnMetaRs 列元信息的ResultSet
* @param table 表信息
* @return 列对象
* @since 5.4.3
*/
public static Column create(Table table, ResultSet columnMetaRs) {
return new Column(table, columnMetaRs);
}
// ----------------------------------------------------- Constructor start
/**
* 构造
*/
@ -54,10 +91,12 @@ public class Column implements Serializable, Cloneable {
/**
* 构造
*
* @param tableName 表名
*
* @param tableName 表名
* @param columnMetaRs Meta信息的ResultSet
* @deprecated 请使用 {@link #Column(Table, ResultSet)}
*/
@Deprecated
public Column(String tableName, ResultSet columnMetaRs) {
try {
init(tableName, columnMetaRs);
@ -65,30 +104,78 @@ public class Column implements Serializable, Cloneable {
throw new DbRuntimeException(StrUtil.format("Get table [{}] meta info error!", tableName));
}
}
/**
* 构造
*
* @param table 表信息
* @param columnMetaRs Meta信息的ResultSet
* @since 5.4.3
*/
public Column(Table table, ResultSet columnMetaRs) {
try {
init(table, columnMetaRs);
} catch (SQLException e) {
throw new DbRuntimeException(StrUtil.format("Get table [{}] meta info error!", tableName));
}
}
// ----------------------------------------------------- Constructor end
/**
* 初始化
*
* @param tableName 表名
*
* @param tableName 表名
* @param columnMetaRs 列的meta ResultSet
* @throws SQLException SQL执行异常
* @deprecated 请使用 {@link #init(Table, ResultSet)}
*/
@Deprecated
public void init(String tableName, ResultSet columnMetaRs) throws SQLException {
init(Table.create(tableName), columnMetaRs);
}
/**
* 初始化
*
* @param table 表信息
* @param columnMetaRs 列的meta ResultSet
* @throws SQLException SQL执行异常
*/
public void init(String tableName, ResultSet columnMetaRs) throws SQLException {
this.tableName = tableName;
public void init(Table table, ResultSet columnMetaRs) throws SQLException {
this.tableName = table.getTableName();
this.name = columnMetaRs.getString("COLUMN_NAME");
this.isPk = table.isPk(this.name);
this.type = columnMetaRs.getInt("DATA_TYPE");
this.typeName = columnMetaRs.getString("TYPE_NAME");
this.size = columnMetaRs.getInt("COLUMN_SIZE");
this.isNullable = columnMetaRs.getBoolean("NULLABLE");
this.comment = columnMetaRs.getString("REMARKS");
// 保留小数位数
try {
this.digit = columnMetaRs.getInt("DECIMAL_DIGITS");
} catch (SQLException ignore) {
//某些驱动可能不支持跳过
}
// 是否自增
try {
String auto = columnMetaRs.getString("IS_AUTOINCREMENT");
if (BooleanUtil.toBoolean(auto)) {
this.autoIncrement = true;
}
} catch (SQLException ignore) {
//某些驱动可能不支持跳过
}
}
// ----------------------------------------------------- Getters and Setters start
/**
* 获取表名
*
*
* @return 表名
*/
public String getTableName() {
@ -97,7 +184,7 @@ public class Column implements Serializable, Cloneable {
/**
* 设置表名
*
*
* @param tableName 表名
* @return this
*/
@ -108,7 +195,7 @@ public class Column implements Serializable, Cloneable {
/**
* 获取列名
*
*
* @return 列名
*/
public String getName() {
@ -117,7 +204,7 @@ public class Column implements Serializable, Cloneable {
/**
* 设置列名
*
*
* @param name 列名
* @return this
*/
@ -128,17 +215,17 @@ public class Column implements Serializable, Cloneable {
/**
* 获取字段类型的枚举
*
*
* @return 阻断类型枚举
* @since 4.5.8
*/
public JdbcType getTypeEnum() {
return JdbcType.valueOf(this.type);
}
/**
* 获取类型对应{@link java.sql.Types}中的类型
*
*
* @return 类型
*/
public int getType() {
@ -147,7 +234,7 @@ public class Column implements Serializable, Cloneable {
/**
* 设置类型对应java.sql.Types中的类型
*
*
* @param type 类型
* @return this
*/
@ -155,19 +242,19 @@ public class Column implements Serializable, Cloneable {
this.type = type;
return this;
}
/**
* 获取类型名称
*
*
* @return 类型名称
*/
public String getTypeName() {
return typeName;
}
/**
* 设置类型名称
*
*
* @param typeName 类型名称
* @return this
*/
@ -178,7 +265,7 @@ public class Column implements Serializable, Cloneable {
/**
* 获取大小或数据长度
*
*
* @return 大小或数据长度
*/
public int getSize() {
@ -187,7 +274,7 @@ public class Column implements Serializable, Cloneable {
/**
* 设置大小或数据长度
*
*
* @param size 大小或数据长度
* @return this
*/
@ -196,9 +283,29 @@ public class Column implements Serializable, Cloneable {
return this;
}
/**
* 获取小数位数
*
* @return 大小或数据长度
*/
public int getDigit() {
return digit;
}
/**
* 设置小数位数
*
* @param digit 小数位数
* @return this
*/
public Column setDigit(int digit) {
this.digit = digit;
return this;
}
/**
* 是否为可空
*
*
* @return 是否为可空
*/
public boolean isNullable() {
@ -207,7 +314,7 @@ public class Column implements Serializable, Cloneable {
/**
* 设置是否为可空
*
*
* @param isNullable 是否为可空
* @return this
*/
@ -218,7 +325,7 @@ public class Column implements Serializable, Cloneable {
/**
* 获取注释
*
*
* @return 注释
*/
public String getComment() {
@ -227,7 +334,7 @@ public class Column implements Serializable, Cloneable {
/**
* 设置注释
*
*
* @param comment 注释
* @return this
*/
@ -235,6 +342,50 @@ public class Column implements Serializable, Cloneable {
this.comment = comment;
return this;
}
/**
* 是否自增
*
* @return 是否自增
* @since 5.4.3
*/
public boolean isAutoIncrement() {
return autoIncrement;
}
/**
* 设置是否自增
*
* @param autoIncrement 是否自增
* @return this
* @since 5.4.3
*/
public Column setAutoIncrement(boolean autoIncrement) {
this.autoIncrement = autoIncrement;
return this;
}
/**
* 是否主键
*
* @return 是否主键
* @since 5.4.3
*/
public boolean isPk() {
return isPk;
}
/**
* 设置是否主键
*
* @param isPk 是否主键
* @return this
* @since 5.4.3
*/
public Column setPk(boolean isPk) {
this.isPk = isPk;
return this;
}
// ----------------------------------------------------- Getters and Setters end
@Override

View File

@ -186,8 +186,10 @@ public class MetaUtil {
conn = ds.getConnection();
// catalog和schema获取失败默认使用null代替
String catalog = getCataLog(conn);
String schema = getSchema(conn);
final String catalog = getCataLog(conn);
table.setCatalog(catalog);
final String schema = getSchema(conn);
table.setSchema(schema);
final DatabaseMetaData metaData = conn.getMetaData();
@ -213,7 +215,7 @@ public class MetaUtil {
try (ResultSet rs = metaData.getColumns(catalog, schema, tableName, null)) {
if (null != rs) {
while (rs.next()) {
table.setColumn(Column.create(tableName, rs));
table.setColumn(Column.create(table, rs));
}
}
}

View File

@ -9,18 +9,31 @@ import java.util.Set;
/**
* 数据库表信息
*
* @author loolly
*
* @author loolly
*/
public class Table implements Serializable, Cloneable {
private static final long serialVersionUID = -810699625961392983L;
/** 表名 */
/**
* table所在的schema
*/
private String schema;
/**
* tables所在的catalog
*/
private String catalog;
/**
* 表名
*/
private String tableName;
/** 注释 */
/**
* 注释
*/
private String comment;
/** 主键字段名列表 */
/**
* 主键字段名列表
*/
private Set<String> pkNames = new LinkedHashSet<>();
private final Map<String, Column> columns = new LinkedHashMap<>();
@ -29,9 +42,10 @@ public class Table implements Serializable, Cloneable {
}
// ----------------------------------------------------- Constructor start
/**
* 构造
*
*
* @param tableName 表名
*/
public Table(String tableName) {
@ -40,9 +54,54 @@ public class Table implements Serializable, Cloneable {
// ----------------------------------------------------- Constructor end
// ----------------------------------------------------- Getters and Setters start
/**
* 获取 schema
*
* @return schema
* @since 5.4.3
*/
public String getSchema() {
return schema;
}
/**
* 设置schema
*
* @param schema schema
* @return this
* @since 5.4.3
*/
public Table setSchema(String schema) {
this.schema = schema;
return this;
}
/**
* 获取catalog
*
* @return catalog
* @since 5.4.3
*/
public String getCatalog() {
return catalog;
}
/**
* 设置catalog
*
* @param catalog catalog
* @return this
* @since 5.4.3
*/
public Table setCatalog(String catalog) {
this.catalog = catalog;
return this;
}
/**
* 获取表名
*
*
* @return 表名
*/
public String getTableName() {
@ -51,7 +110,7 @@ public class Table implements Serializable, Cloneable {
/**
* 设置表名
*
*
* @param tableName 表名
*/
public void setTableName(String tableName) {
@ -60,7 +119,7 @@ public class Table implements Serializable, Cloneable {
/**
* 获取注释
*
*
* @return 注释
*/
public String getComment() {
@ -69,7 +128,7 @@ public class Table implements Serializable, Cloneable {
/**
* 设置注释
*
*
* @param comment 注释
* @return this
*/
@ -80,16 +139,27 @@ public class Table implements Serializable, Cloneable {
/**
* 获取主键列表
*
*
* @return 主键列表
*/
public Set<String> getPkNames() {
return pkNames;
}
/**
* 给定列名是否为主键
*
* @param columnName 列名
* @return 是否为主键
* @since 5.4.3
*/
public boolean isPk(String columnName){
return getPkNames().contains(columnName);
}
/**
* 设置主键列表
*
*
* @param pkNames 主键列表
*/
public void setPkNames(Set<String> pkNames) {
@ -99,7 +169,7 @@ public class Table implements Serializable, Cloneable {
/**
* 设置列对象
*
*
* @param column 列对象
* @return 自己
*/
@ -110,7 +180,7 @@ public class Table implements Serializable, Cloneable {
/**
* 获取某列信息
*
*
* @param name 列名
* @return 列对象
* @since 4.2.2
@ -121,7 +191,7 @@ public class Table implements Serializable, Cloneable {
/**
* 获取所有字段元信息
*
*
* @return 字段元信息集合
* @since 4.5.8
*/
@ -131,7 +201,7 @@ public class Table implements Serializable, Cloneable {
/**
* 添加主键
*
*
* @param pkColumnName 主键的列名
* @return 自己
*/