日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java long 对应mybati类型_修改 mybatis-generator 中数据库类型和 Java 类型的映射关系...

發布時間:2025/4/5 java 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java long 对应mybati类型_修改 mybatis-generator 中数据库类型和 Java 类型的映射关系... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

使用 mybatis-generator 發現數據庫類型是 tinyint(4) , 生成 model 時字段類型是 Byte ,使用的時候有點不便

數據庫的類型和 Model 中 Java 類型的關系是由 JavaTypeResolver 控制的, 查資料發現可以在生成配置中指定表中的某一個字段的 JavaType, 但不能全局配置.

如果想改某一個表的話某個字段, 只需要在 table 標簽下指定 即可

如果想要改全局就沒那么容易了.

查看配置文檔發現有一個 javaTypeResolver 標簽, 有一個生成器的默認實現

package org.mybatis.generator.internal.types;

import java.math.BigDecimal;

import java.sql.Types;

import java.util.Date;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import java.util.Properties;

import org.mybatis.generator.api.IntrospectedColumn;

import org.mybatis.generator.api.JavaTypeResolver;

import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;

import org.mybatis.generator.config.Context;

import org.mybatis.generator.config.PropertyRegistry;

import org.mybatis.generator.internal.util.StringUtility;

/**

*

* @author Jeff Butler

*/

public class JavaTypeResolverDefaultImpl implements JavaTypeResolver {

protected List warnings;

protected Properties properties;

protected Context context;

protected boolean forceBigDecimals;

protected Map typeMap;

public JavaTypeResolverDefaultImpl() {

super();

properties = new Properties();

typeMap = new HashMap();

typeMap.put(Types.ARRAY, new JdbcTypeInformation("ARRAY", //$NON-NLS-1$

new FullyQualifiedJavaType(Object.class.getName())));

typeMap.put(Types.BIGINT, new JdbcTypeInformation("BIGINT", //$NON-NLS-1$

new FullyQualifiedJavaType(Long.class.getName())));

typeMap.put(Types.BINARY, new JdbcTypeInformation("BINARY", //$NON-NLS-1$

new FullyQualifiedJavaType("byte[]"))); //$NON-NLS-1$

typeMap.put(Types.BIT, new JdbcTypeInformation("BIT", //$NON-NLS-1$

new FullyQualifiedJavaType(Boolean.class.getName())));

等等等...

可以發現是把數據庫類型和 JavaType 使用 map 映射起來了, 要是能改這個東西就好了

在網上搜索沒有找到合適的擴展點, 在官方倉庫中搜到了一點相關的東西

如果想控制映射關系, 有兩個方案

編寫一個插件

擴展 JavaTypeResolverDefaultImpl 并更改 calculateJavaType 方法, 在 TypeResolver 配置自己的實現

顯然第二個實現起來比較簡單, 我們的要求不是很復雜, 不用修改 calculateJavaType, 所以可以直接覆蓋 org.mybatis.generator.internal.types.JavaTypeResolverDefaultImpl#typeMap 中的映射關系

首先把 mybatis-generator 源碼拉下來 ,打開 org.mybatis.generator.internal.types 包新建一個類, 繼承原有的 JavaTypeResolverDefaultImpl, 然后在構造中覆蓋原有配置

package org.mybatis.generator.internal.types;

import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;

import java.sql.Types;

public class MyJavaTypeResolverDefaultImpl extends JavaTypeResolverDefaultImpl {

public MyJavaTypeResolverDefaultImpl() {

super();

//把數據庫的 TINYINT 映射成 Integer

super.typeMap.put(Types.TINYINT, new JdbcTypeInformation("TINYINT", new FullyQualifiedJavaType(Integer.class.getName())));

}

}

完成以后整體 install 到本地, 拉下來的版本號是 1.3.7-SNAPSHOT, 注意改一下自己項目依賴的版本號

在生成配置文件中把 javaTypeResolver 修改成自己的實現類

這樣的話生成代碼時就會把數據庫的 tinyint 變成 Java 中的 Integer

總結

以上是生活随笔為你收集整理的java long 对应mybati类型_修改 mybatis-generator 中数据库类型和 Java 类型的映射关系...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。