hibernate生成实体规则

本文介绍了一种定制化的Hibernate反向工程策略,该策略通过覆盖默认的行为来改变表和字段映射到Java对象的方式。具体而言,它定义了新的规则用于生成POJO类的名称及其属性名称。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.jn0812a.crm.commons.utils;

import org.hibernate.cfg.reveng.DelegatingReverseEngineeringStrategy;
import org.hibernate.cfg.reveng.ReverseEngineeringStrategy;
import org.hibernate.cfg.reveng.TableIdentifier;

/**
*
* @author Wuhuihe
*
*
*/
public class HibernateStrategy extends DelegatingReverseEngineeringStrategy {

public HibernateStrategy(ReverseEngineeringStrategy arg0) {
super(arg0);
}

/*
* 重写字段反向生成POJO类中的成员变量的命名规则 如果字段中含有下划线,默认第一个下划线之前的字符为前缀,将被删除。去除前缀后,
* 第一个字母大写,其他字母全部小写,如果后面有下划线去除下划线。
*
*/
@Override
public String columnToPropertyName(TableIdentifier table, String column) {

if (column != null) {
String[] tmp = column.split("_");
// 最终的表名
String finalPropertyName = "";
if (tmp.length == 1) {
// 没有下划线
finalPropertyName = tmp[0].toLowerCase();
} else {
//有下划线,默认去除前缀
for (int i = 1; i < tmp.length; i++) {
finalPropertyName = finalPropertyName + tmp[i].toLowerCase();
}
}
return finalPropertyName;
}
return "";
}

/*
* 重写表反向生成PoJO类的命名规则 注意:第一个下划线之前的位置为前缀,将被删除。去除前缀后,
* 第一个字母大写,其他字母全部小写,如果后面有下划线去除下划线,并对下划线后的第一个字母大写
* 如:表VIP_CUSTOMER生成的POJO类为Customer
* 表VIP_CUSTOMER_EXTEND生成的POJO类为CustomerExtend;
*/
@Override
public String tableToClassName(TableIdentifier table) {
// TODO Auto-generated method stub
if (table != null) {
// 先获取包路径
String prifix = super.tableToClassName(table);
int lastpoint = prifix.lastIndexOf(".");
String packagename = prifix.substring(0, lastpoint + 1);
//JOptionPane.showMessageDialog(null,packagename);
String tablename = table.getName();
String[] tmp = tablename.split("_");
// 最终的表名
String finalClassName = "";
String firstChar = "";
String otherChar = "";
if (tmp.length == 1) {
// 没有下划线
firstChar = tmp[0].substring(0, 1).toUpperCase();
otherChar = tmp[0].substring(1).toLowerCase();
finalClassName = firstChar + otherChar;
} else {
for (int i = 1; i < tmp.length; i++) {
firstChar = tmp[i].substring(0, 1).toUpperCase();
otherChar = tmp[i].substring(1).toLowerCase();
finalClassName = finalClassName + firstChar + otherChar;
}
}
return packagename + finalClassName;
} else {

return super.tableToClassName(table);
}

}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值