注意,引用的是javax.persistence.Column和javax.persistence.Table,起初我以为注解既然配置的是Hibernate的实体用的,是不是应该引用hibernate包下的table和column,后来出了问题,找了好长时间才发现问题出在应该引用的不是hibernate包里的,方法可以写main方法测试。
import java.lang.annotation.Annotation;
import java.lang.reflect.Field;
import javax.persistence.Column;
import javax.persistence.Table;
/**
* 获取字段
*
* @param classtype
*/
@SuppressWarnings(value = { "rawtypes" })
public static Map<String, String> getColumns(Class classtype) {
Field[] fields = classtype.getDeclaredFields();
Map<String, String> map = new HashMap<String, String>();
for (int i = 0; i < fields.length; i++) {
Annotation[] annotations = fields[i].getAnnotations();
for (int j = 0; j < annotations.length; j++) {
if (annotations[j] instanceof Column) {
Column column = (Column) annotations[j];
System.out.print(fields[i].getName() + "、");
System.out.println(column.name());
map.put(fields[i].getName(), column.name());
}
}
}
return map;
}
/**
* 获取表名
*
* @param classtype
* @return
*/
@SuppressWarnings(value = { "rawtypes" })
public static String getTableName(Class classtype) {
Annotation[] anno = classtype.getAnnotations();
String tableName = "";
for (int i = 0; i < anno.length; i++) {
if (anno[i] instanceof Table) {
Table table = (Table) anno[i];
System.out.println(table.name());
tableName = table.name();
}
}
return tableName;
}
分享到:
相关推荐
例如,如果有一个名为`User`的表,我们可以创建一个`User.java`类,使用`@Entity`注解标识它,并使用`@Table`指定对应的表名,以及其他的字段映射注解如`@Id`, `@GeneratedValue`, `@Column`等。 在Spring中,我们...
在开始之前,确保已搭建好Java开发环境,包括JDK的安装和配置、Eclipse或IntelliJ IDEA等IDE的选择以及Maven等构建工具的准备。接下来,具体步骤如下: #### 1. 新建项目 - 使用IDE(如Eclipse)创建一个新的Java ...
此外,为了提高代码的可读性和可维护性,生成的实体类可能会引入一些注解,如`@Entity`(表示这是一个JPA实体)、`@Table`(指定对应的数据库表名)、`@Column`(指定字段名和类型)等。这些注解来自Java ...
这些元数据包括表名、字段名、字段类型等,这些信息将用于构建实体类的属性和方法。 在标签中,“bean 实体 数据库 生成”暗示了这个过程可能涉及到Java Bean的生成。Java Bean是一种符合特定规范的Java类,常用于...