实体类,
@Entity
public class H {
@GeneratedValue(strategy = GenerationType.AUTO)
@Id
private int id;
private String name;
private Operation op;
public H(){}
public H(String name, Operation op){
this.name = name;
this.op = op;
}
//getters and setters...
}
上面类中op是个枚举对象,
public enum Operation {
PLUS("+"),
MINUS("-"),
TIMES("*") ,
DIVIDE("/");
private final String symbol;
Operation(String symbol) {
this.symbol = symbol;
}
@Override
public String toString() {
return symbol;
}
}
测试代码如下,
EntityManagerFactory emf = Persistence.createEntityManagerFactory("NewExpensePU");
EntityManager em1 = emf.createEntityManager();
em1.getTransaction().begin();
H h = new H("*", Operation.TIMES);
em1.persist(h);
em1.getTransaction().commit();
em1.close();
EntityManager em2 = emf.createEntityManager();
em2.getTransaction().begin();
H result = em2.find(H.class, h.getId());
System.out.println(result.getOp());
em2.getTransaction().commit();
em2.close();
emf.close();
于是发现,JPA或者说ORM框架对付枚举完全木问题,数据中存储枚举对象的形式是个smallint(6),MySql是这样的。
其实,还是源于这句话“Java的枚举本质上是int值”。
再说枚举的两个重要方法,第一个,name()——用于获取枚举对象声明时的名称,有此方法便可以放心大胆地重写toString()了~
第二个,ordinal()——返回枚举常量的序数。(这个方法十分重要,如果你不知道它,就会十分疑问ORM框架是怎么将Enum的int值存入数据库的,就像我半小时前一样)
这样,适用JDBC的代码就很好写了吧...无非写sql语句时insert枚举的ordinal()
记一下使用JDBC的代码吧,我都快忘记了....
public class DataConnect {
private Connection con = null;
private Statement stat = null;
private PreparedStatement pstat = null;
private ResultSet rs = null;
public Connection getCon() {
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
StringBuilder sd = new StringBuilder("jdbc:mysql://");
sd.append("localhost:3306");
sd.append("/");
sd.append("newexpense");//database name
String url = sd.toString();
DriverManager.setLoginTimeout(10);//设置连接超时为10秒
con = DriverManager.getConnection(url, "root", "root");
} catch (Exception ex) {
Logger.getLogger(DataConnect.class.getName()).log(Level.SEVERE, null, ex);
}
return con;
}
public ResultSet query(String sql) {
try {
stat = con.createStatement();
rs = stat.executeQuery(sql);
} catch (Exception ex) {
Logger.getLogger(DataConnect.class.getName()).log(Level.SEVERE, null, ex);
}
return rs;
}
public void update(String sql) {//千万别close !!!
try {
stat = con.createStatement();
stat.executeUpdate(sql);
} catch (Exception ex) {
Logger.getLogger(DataConnect.class.getName()).log(Level.SEVERE, null, ex);
}
}
public void update(String sql, String[] args) {
try {
pstat = con.prepareStatement(sql);
for (int i = 0; i < args.length; i++) {
pstat.setString(i + 1, args[i]);
}
pstat.executeUpdate();
} catch (Exception ex) {
Logger.getLogger(DataConnect.class.getName()).log(Level.SEVERE, null, ex);
}
}
public void close() {
//check null,then close rs,stat,pstat and con.
}
}
这里面使用的类都是java.sql包的,
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
分享到:
相关推荐
对于日期、大文本、二进制文本和枚举字段的处理,JPA会自动进行转换,使它们能够在数据库中正确存储和检索。 在“JPA_Dome”压缩包中,可能包含了上述示例的完整代码,你可以下载并运行这些代码以加深理解。通过...
- **@Enumerated**:用于枚举类型的属性,可以指定枚举值的存储方式。 - **@Lob**:用于大对象类型的数据,如图像或文本。 - **@Transient**:表示该属性不会被持久化。 #### 四、JPA的增删改操作 JPA提供了丰富的...
- 提供一系列用于操作实体对象的方法,如 CRUD 操作,使得开发者无需直接编写复杂的 JDBC 或 SQL 代码。 - **JPQL 查询语言**: - 面向对象的查询语言,允许开发者使用类名、属性名等面向对象的概念进行查询,而...
在Java开发中,数据库操作是不可或缺的一部分,MySQL作为广泛应用的关系型数据库,经常被用来存储和管理数据。将MySQL中的表映射到Java实体类是一种常见的做法,它使得开发者可以通过对象的方式来操作数据库,大大...
1. 创建数据源枚举类,用于存储数据源名称: ```java public enum DataSourceType { PRIMARY, SECONDARY } ``` 2. 创建一个自定义注解,如`@SwitchDataSource`,用于标记需要切换数据源的方法: ```java @Target...
确保包含`spring-boot-starter-data-jpa`、`mybatis-spring-boot-starter`和可能需要的数据库驱动依赖。 接着,创建两个或多个数据源配置。每个数据源都需要一个`DataSource`实例,可以通过`@...
3. **数据库**(数据库.md):数据库是数据存储的核心,Java开发者需要熟悉SQL语言,理解关系型数据库(如MySQL、Oracle)的基本概念,如ACID特性、索引优化、事务管理以及JDBC操作。 4. **Spring框架**(Spring.md...
**高级集合框架**:Java集合框架是存储和操作对象的关键,书中深入解析了List、Set、Queue、Map接口及其实现类,如ArrayList、LinkedList、HashSet、TreeSet、HashMap、ConcurrentHashMap等,还涵盖了泛型、枚举和...
12. **JDBC**:Java数据库连接(JDBC)是Java访问数据库的标准API,可以用来执行SQL查询、更新数据、处理结果集等。 13. **Java EE**:Java企业版扩展了Java SE,提供Web应用开发所需的服务,如Servlet、JSP、EJB、...
15. **Web框架**:如Spring MVC,Struts,Hibernate,MyBatis,JPA,EJB等,用于构建J2EE应用程序。前端技术包括JavaScript,jQuery,JSP/servlet,以及数据库操作工具JDBC。 16. **缓存**:Ehcache用于提高应用...
JAR 文件是一种压缩文件,用于存储 Java 类和资源。 53. Java 异常处理 * Java 中如何处理异常?使用 try-catch 语句块处理异常。 54. Java final 关键字 * Java 中什么是 final 关键字?final 关键字用于修饰类...
它包括一系列标准和技术,如Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JPA(Java Persistence API)等,用于处理Web应用、企业服务、数据库交互和并发处理。 1. **枚举...
- 掌握接口如List、Set、Map,以及迭代器(Iterator)和枚举(Enumeration)的使用。 **3. 界面编程(了解)** - **AWT**:了解基本的窗口和组件,如Frame、Button、Label等。 - **事件机制**:理解事件监听和...
以上只是Java中构建和管理数据字典的一些基本知识点,实际应用中可能还会涉及更多高级特性和技术,比如分布式缓存、数据持久化框架(如JPA、Hibernate)等。了解并熟练掌握这些知识点,对于提升Java项目的数据管理...
11. **枚举和注解**:枚举是限定的类,常用于定义固定的值,而注解则提供元数据,用于编译时或运行时进行检查或自动生成代码。 12. **Lambda表达式**:Java 8引入的新特性,简化了函数式编程,尤其是在处理集合和...
10. **Java集合高级**:深入理解List、Set、Map接口的实现类,如LinkedList、TreeSet、ConcurrentHashMap等,以及泛型、枚举和接口的使用。 11. **Java的网络编程**:学习Socket编程,如何创建服务器端和客户端,...
对JDBC和ORM框架的支持进一步加强,包括Hibernate和JPA。Spring 2.1提供了更强大的事务管理功能,以及对存储过程的支持,使得数据库操作更为便捷。 5. **Web增强**: 在Web层,Spring 2.1对MVC框架进行了优化,...
- **常见的O/R框架**:对比分析Hibernate与其他O/R Mapping框架如TopLink、JDO、JPA的特点。 - **Hibernate基础配置**:详细介绍`hibernate.cfg.xml`文件中的关键配置项,如`hbm2ddl.auto`等。 - **ID生成策略**:...
- JPA #### 三、Hibernate基础配置 - **项目:Hibernate_0300_BasicConfiguration** - 使用MySQL图形化客户端 - 配置`hibernate.cfg.xml`中的`hbni2ddl.auto`属性 - 设置日志环境以显示DDL语句 - 集成JUnit...
- **JPA**:Kotlin 可以与 JPA 框架一起使用,通过 `kotlin-jpa` 编译器插件来适应框架的要求。 - **NoSQL 数据库**:Kotlin 支持通过相应的 Java 驱动程序进行 NoSQL 数据库的持久化。 #### 部署选项 - **Amazon ...