`
keating
  • 浏览: 170703 次
  • 性别: Icon_minigender_1
  • 来自: weihai
社区版块
存档分类
最新评论

JDBC,JPA存储枚举..

    博客分类:
  • Java
阅读更多
实体类,
@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会自动进行转换,使它们能够在数据库中正确存储和检索。 在“JPA_Dome”压缩包中,可能包含了上述示例的完整代码,你可以下载并运行这些代码以加深理解。通过...

    JPA实体bean配置,jpa增删改api,jpasql增删改.doc

    - **@Enumerated**:用于枚举类型的属性,可以指定枚举值的存储方式。 - **@Lob**:用于大对象类型的数据,如图像或文本。 - **@Transient**:表示该属性不会被持久化。 #### 四、JPA的增删改操作 JPA提供了丰富的...

    传智播客JPA学习笔记修改免积分版

    - 提供一系列用于操作实体对象的方法,如 CRUD 操作,使得开发者无需直接编写复杂的 JDBC 或 SQL 代码。 - **JPQL 查询语言**: - 面向对象的查询语言,允许开发者使用类名、属性名等面向对象的概念进行查询,而...

    Mysql映射java实体类

    在Java开发中,数据库操作是不可或缺的一部分,MySQL作为广泛应用的关系型数据库,经常被用来存储和管理数据。将MySQL中的表映射到Java实体类是一种常见的做法,它使得开发者可以通过对象的方式来操作数据库,大大...

    SpringBoot使用AOP完成多数据源切换

    1. 创建数据源枚举类,用于存储数据源名称: ```java public enum DataSourceType { PRIMARY, SECONDARY } ``` 2. 创建一个自定义注解,如`@SwitchDataSource`,用于标记需要切换数据源的方法: ```java @Target...

    SpringBoot-MyBatis-DataSource(多数据源以及动态切换)

    确保包含`spring-boot-starter-data-jpa`、`mybatis-spring-boot-starter`和可能需要的数据库驱动依赖。 接着,创建两个或多个数据源配置。每个数据源都需要一个`DataSource`实例,可以通过`@...

    关于java 面试相关的资料md格式

    3. **数据库**(数据库.md):数据库是数据存储的核心,Java开发者需要熟悉SQL语言,理解关系型数据库(如MySQL、Oracle)的基本概念,如ACID特性、索引优化、事务管理以及JDBC操作。 4. **Spring框架**(Spring.md...

    Core Java(Volume II--Advanced Features 9th Edition).pdf

    **高级集合框架**:Java集合框架是存储和操作对象的关键,书中深入解析了List、Set、Queue、Map接口及其实现类,如ArrayList、LinkedList、HashSet、TreeSet、HashMap、ConcurrentHashMap等,还涵盖了泛型、枚举和...

    JAVA核心知识点整理.rar

    12. **JDBC**:Java数据库连接(JDBC)是Java访问数据库的标准API,可以用来执行SQL查询、更新数据、处理结果集等。 13. **Java EE**:Java企业版扩展了Java SE,提供Web应用开发所需的服务,如Servlet、JSP、EJB、...

    java编程语言的知识结构_副本_76941.pdf

    15. **Web框架**:如Spring MVC,Struts,Hibernate,MyBatis,JPA,EJB等,用于构建J2EE应用程序。前端技术包括JavaScript,jQuery,JSP/servlet,以及数据库操作工具JDBC。 16. **缓存**:Ehcache用于提高应用...

    74个java面试题,只有题目没有答案

    JAR 文件是一种压缩文件,用于存储 Java 类和资源。 53. Java 异常处理 * Java 中如何处理异常?使用 try-catch 语句块处理异常。 54. Java final 关键字 * Java 中什么是 final 关键字?final 关键字用于修饰类...

    知识领域 JavaEE 技术关键词 JavaEE初级工程师前一年的工作开发日志记录 内容

    它包括一系列标准和技术,如Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JPA(Java Persistence API)等,用于处理Web应用、企业服务、数据库交互和并发处理。 1. **枚举...

    java学习路线

    - 掌握接口如List、Set、Map,以及迭代器(Iterator)和枚举(Enumeration)的使用。 **3. 界面编程(了解)** - **AWT**:了解基本的窗口和组件,如Frame、Button、Label等。 - **事件机制**:理解事件监听和...

    JAVA中的数据字典

    以上只是Java中构建和管理数据字典的一些基本知识点,实际应用中可能还会涉及更多高级特性和技术,比如分布式缓存、数据持久化框架(如JPA、Hibernate)等。了解并熟练掌握这些知识点,对于提升Java项目的数据管理...

    java100例,java的经典例子

    11. **枚举和注解**:枚举是限定的类,常用于定义固定的值,而注解则提供元数据,用于编译时或运行时进行检查或自动生成代码。 12. **Lambda表达式**:Java 8引入的新特性,简化了函数式编程,尤其是在处理集合和...

    21天学通Java源代码

    10. **Java集合高级**:深入理解List、Set、Map接口的实现类,如LinkedList、TreeSet、ConcurrentHashMap等,以及泛型、枚举和接口的使用。 11. **Java的网络编程**:学习Socket编程,如何创建服务器端和客户端,...

    Spring Framework 2.1 第一预览版

    对JDBC和ORM框架的支持进一步加强,包括Hibernate和JPA。Spring 2.1提供了更强大的事务管理功能,以及对存储过程的支持,使得数据库操作更为便捷。 5. **Web增强**: 在Web层,Spring 2.1对MVC框架进行了优化,...

    马士兵hibernate学习笔记(原版)

    - **常见的O/R框架**:对比分析Hibernate与其他O/R Mapping框架如TopLink、JDO、JPA的特点。 - **Hibernate基础配置**:详细介绍`hibernate.cfg.xml`文件中的关键配置项,如`hbm2ddl.auto`等。 - **ID生成策略**:...

    hibernate课程详解

    - JPA #### 三、Hibernate基础配置 - **项目:Hibernate_0300_BasicConfiguration** - 使用MySQL图形化客户端 - 配置`hibernate.cfg.xml`中的`hbni2ddl.auto`属性 - 设置日志环境以显示DDL语句 - 集成JUnit...

    kotlin-docs.pdf

    - **JPA**:Kotlin 可以与 JPA 框架一起使用,通过 `kotlin-jpa` 编译器插件来适应框架的要求。 - **NoSQL 数据库**:Kotlin 支持通过相应的 Java 驱动程序进行 NoSQL 数据库的持久化。 #### 部署选项 - **Amazon ...

Global site tag (gtag.js) - Google Analytics