hibernate 直接通过表名,获取字段名及字段类型??
6个回答
2015-08-09 · 知道合伙人互联网行家
关注
展开全部
/**
* 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
* </p>
* 注:po类名须与对应映射文件名一致,即Student.java与Student.hbm.xml
*
* @Date:Nov 10, 2008
* @Time:3:13:07 PM
*
*/
public class HibernateConfigurationHelper {
private static Configuration hibernateConf;
@SuppressWarnings("unused")
private static Configuration getHibernateConf() {
if (hibernateConf == null) {
return new Configuration();
}
return hibernateConf;
}
@SuppressWarnings("unchecked")
private static PersistentClass getPersistentClass(Class clazz) {
synchronized (HibernateConfigurationHelper.class) {
PersistentClass pc = getHibernateConf().getClassMapping(
clazz.getName());
if (pc == null) {
hibernateConf = getHibernateConf().addClass(clazz);
pc = getHibernateConf().getClassMapping(clazz.getName());
}
return pc;
}
}
/**
* 功能描述:获取实体对应的表名
*
* @param clazz
* 实体类
* @return 表名
*/
@SuppressWarnings("unchecked")
public static String getTableName(Class clazz) {
return getPersistentClass(clazz).getTable().getName();
}
/**
* 功能描述:获取实体对应表的主键字段名称
*
* @param clazz
* 实体类
* @return 主键字段名称
*/
@SuppressWarnings("unchecked")
public static String getPkColumnName(Class clazz) {
return getPersistentClass(clazz).getTable().getPrimaryKey()
.getColumn(0).getName();
}
/**
* 功能描述:通过实体类和属性,获取实体类属性对应的表字段名称
*
* @param clazz
* 实体类
* @param propertyName
* 属性名称
* @return 字段名称
*/
@SuppressWarnings("unchecked")
public static String getColumnName(Class clazz, String propertyName) {
PersistentClass persistentClass = getPersistentClass(clazz);
Property property = persistentClass.getProperty(propertyName);
Iterator it = property.getColumnIterator();
if (it.hasNext()) {
Column column = (Column) it.next();
return column.getName();
}
return null;
}
/**
* @param args
*/
public static void main(String[] args) {
System.out.println(getTableName(IntelligenceNetVPNAndSCP.class));
System.out.println(getColumnName(IntelligenceNetVPNAndSCP.class,
"vsCode"));
}
}
* 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
* </p>
* 注:po类名须与对应映射文件名一致,即Student.java与Student.hbm.xml
*
* @Date:Nov 10, 2008
* @Time:3:13:07 PM
*
*/
public class HibernateConfigurationHelper {
private static Configuration hibernateConf;
@SuppressWarnings("unused")
private static Configuration getHibernateConf() {
if (hibernateConf == null) {
return new Configuration();
}
return hibernateConf;
}
@SuppressWarnings("unchecked")
private static PersistentClass getPersistentClass(Class clazz) {
synchronized (HibernateConfigurationHelper.class) {
PersistentClass pc = getHibernateConf().getClassMapping(
clazz.getName());
if (pc == null) {
hibernateConf = getHibernateConf().addClass(clazz);
pc = getHibernateConf().getClassMapping(clazz.getName());
}
return pc;
}
}
/**
* 功能描述:获取实体对应的表名
*
* @param clazz
* 实体类
* @return 表名
*/
@SuppressWarnings("unchecked")
public static String getTableName(Class clazz) {
return getPersistentClass(clazz).getTable().getName();
}
/**
* 功能描述:获取实体对应表的主键字段名称
*
* @param clazz
* 实体类
* @return 主键字段名称
*/
@SuppressWarnings("unchecked")
public static String getPkColumnName(Class clazz) {
return getPersistentClass(clazz).getTable().getPrimaryKey()
.getColumn(0).getName();
}
/**
* 功能描述:通过实体类和属性,获取实体类属性对应的表字段名称
*
* @param clazz
* 实体类
* @param propertyName
* 属性名称
* @return 字段名称
*/
@SuppressWarnings("unchecked")
public static String getColumnName(Class clazz, String propertyName) {
PersistentClass persistentClass = getPersistentClass(clazz);
Property property = persistentClass.getProperty(propertyName);
Iterator it = property.getColumnIterator();
if (it.hasNext()) {
Column column = (Column) it.next();
return column.getName();
}
return null;
}
/**
* @param args
*/
public static void main(String[] args) {
System.out.println(getTableName(IntelligenceNetVPNAndSCP.class));
System.out.println(getColumnName(IntelligenceNetVPNAndSCP.class,
"vsCode"));
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
hibernate是将数据库中的表与类进行关联的OR Mapping映射,将数据库中的表映射到实体类中了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不是表名,映射过来的类名,
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
hibernate 没有表名的概念 只有类名的概念
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询