hibernate 直接通过表名,获取字段名及字段类型??

 我来答
ynby369258
2013-04-27
知道答主
回答量:10
采纳率:0%
帮助的人:15.6万
展开全部
hibernate是一个orm面向对象操作的框架,将表映射成一个PO实体类,表的字段映射为PO的字段,表的每一条记录映射为PO的实例。 但是hibernate也是支持原生态的SQL,也是可以通过select t.name from T_User t where t.id = ? 这种方式获取结果
百度网友96ffcf7
2015-08-09 · 知道合伙人互联网行家
百度网友96ffcf7
知道合伙人互联网行家
采纳数:22721 获赞数:118720
从事多年网络方面工作,有丰富的互联网经验。

向TA提问 私信TA
展开全部
/**
* 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
* </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"));
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
黛儿宝儿
2013-04-28 · 贡献了超过253个回答
知道答主
回答量:253
采纳率:0%
帮助的人:54.6万
展开全部
hibernate是将数据库中的表与类进行关联的OR Mapping映射,将数据库中的表映射到实体类中了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
boby_1206
2013-04-27 · TA获得超过100个赞
知道答主
回答量:203
采纳率:0%
帮助的人:67.4万
展开全部
不是表名,映射过来的类名,
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
会拐角的爱
2013-04-27
知道答主
回答量:36
采纳率:0%
帮助的人:18.5万
展开全部
hibernate 没有表名的概念 只有类名的概念
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式