//配置uuid,本来jpa是不支持uuid的,但借用hibernate的方法可以实现。

@GeneratedValue(generator = "uuid")

@GeneratedValue(generator = "uuid") @GenericGenerator(name = "uuid", strategy = "uuid")

加在id的get方法上面

下面具体操作下:

1.同样的 先新建一个java project。

2.导入hibernate插件(选中项目单击鼠标右键-->my eclipse-->project  facets-->hibernate-->next-->新建一个包选中-->next-->去掉上面那个勾-->finsish)。

3.可以发现在src目录下有了一个包 还有一个类。

4.新建一个Teacher类  代码如下:

  1. package com.cqvie;
  2.  
  3. import javax.persistence.Column;
  4. import javax.persistence.GeneratedValue;
  5. import javax.persistence.Id;
  6. import javax.persistence.Table;
  7. import org.hibernate.annotations.GenericGenerator;
  8.  
  9. @javax.persistence.Entity
  10. @Table
  11. public class Teacher {
  12. private String id;
  13. private String name;
  14. private String title;
  15. //设置主键
  16. @Id
    //配置uuid,本来jpa是不支持uuid的,但借用hibernate的方法可以实现。
  17. @GeneratedValue(generator = "uuid")
  18. @GenericGenerator(name = "uuid", strategy = "uuid")
  19. public String getId() {
  20. return id;
  21. }
  22. public void setId(String id) {
  23. this.id = id;
  24. }
  25.  
  26. public String getName() {
  27. return name;
  28. }
  29. public void setName(String name) {
  30. this.name = name;
  31. }
  32. public String getTitle() {
  33. return title;
  34. }
  35. public void setTitle(String title) {
  36. this.title = title;
  37. }
  38.  
  39. }

5.配置hibernate.cfg.xml文件:

  1. <?xml version='1.0' encoding='UTF-8'?>
  2. <!DOCTYPE hibernate-configuration PUBLIC
  3. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  4. "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
  5. <!-- Generated by MyEclipse Hibernate Tools. -->
  6. <hibernate-configuration>
  7.  
  8. <session-factory>
  9.  
  10. <!-- Database connection settings 用到的驱动、数据库名、用户名、密码 -->
  11. <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
  12. <property name="connection.url">jdbc:mysql://localhost/text</property>
  13. <property name="connection.username">root</property>
  14. <property name="connection.password">root</property>
  15.  
  16. <!-- JDBC connection pool (use the built-in) -->
  17. <!-- <property name="connection.pool_size">1</property>-->
  18.  
  19. <!-- SQL dialect 数据库方言-->
  20. <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
  21.  
  22. <!-- Enable Hibernate's automatic session context management -->
  23. <property name="current_session_context_class">thread</property>
  24.  
  25. <!-- Disable the second-level cache -->
  26. <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
  27.  
  28. <!-- Echo all executed SQL to stdout-->
  29. <property name="show_sql">true</property>
  30.  
  31. <!-- Drop and re-create the database schema on startup -->
  32. <property name="hbm2ddl.auto">update</property>
  33.  
  34. <!-- 将有映射的类告诉配置文件 -->
  35. <mapping class="com.cqvie.Teacher"/>
  36. </session-factory>
  37. </hibernate-configuration>

6.将mysql驱动导入项目。

  1. 在项目中新建一个文件夹
  2. 将驱动放入文件夹
  3. 选中驱动鼠标右键 build Path -->add

8.在com.cqvie 包下新建一个测试类TeacherTest

  1. package com.cqvie;
  2.  
  3. import org.hibernate.Session;
  4. import org.hibernate.SessionFactory;
  5. import org.hibernate.cfg.AnnotationConfiguration;
  6. import org.hibernate.cfg.Configuration;
  7.  
  8. public class testTeacher {
  9.  
  10. public static void main(String[] args) {
  11.  
  12. Teacher t= new Teacher();
  13. //uuid已经自动生成,不需要手动添加了
  14. //t.setId(1);
  15. t.setName("s1");
  16. t.setTitle("教授");
  17.  
  18. // Session session=HibernateSessionFactory.getSession();
  19.  
  20. Configuration cfg= new Configuration();
  21. SessionFactory sf=cfg.configure().buildSessionFactory();
  22. Session session=sf.openSession();
  23. session.beginTransaction();
  24. session.save(t);
  25. session.getTransaction().commit();
  26. session.close();
  27. }
  28. }

9.运行结果如下:

这样uuid就生成了!

需要注意的是:

1.id不能再用int类型,而是改用string类型,因为uuid很长而且有字母。

2.需要将映射告诉配置文件

3.注解中添加的包一般都是javax的而不是hibernate的

hibernate 用注解方式生成uuid方法的更多相关文章

  1. hibernate annotation注解方式来处理映射关系

    在hibernate中,通常配置对象关系映射关系有两种,一种是基于xml的方式,另一种是基于annotation的注解方式,熟话说,萝卜青菜,可有所爱,每个人都有自己喜欢的配置方式,我在试了这两种方式 ...

  2. Elasticsearch-mapper 基于注解方式生成mapping(2.0以上)

    Elasticsearch生成mapping的方式上有多种方式,我们可以把mapping做成配置文件,也可以用spring-data-elasticsearch基于注解生成. 在基于注解生成这种方式上 ...

  3. SQL语句中生成UUID方法

    SQL语句中生成UUID方法为UUID() 生成带横线UUID: select UUID()                         形如:abaffaca-fd55-11e5-b3d0-d2 ...

  4. 使用注解方式生成Hibernate映射文件

    @Entity:表示是一个hibernate的实体类 @Table:表示实体类和表的对应关系 @Id:表示是数据库中的主键 @Column:在数据表中描述的对应的列的信息 属性名是根据get方法,数据 ...

  5. Hibernate基于注解方式配置来实现实体和数据库之间存在某种映射关系

    实体和数据库之间存在某种映射关系,hibernate根据这种映射关系完成数据的存取.在程序中这种映射关系由映射文件(*.hbm.xml)或者java注解(@)定义. 本文以java注解的形式总结映射关 ...

  6. Hibernate基于注解方式的各种映射全面总结

    1. 使用Hibernate Annotation来做对象关系映射 1) 添加必须包: hibernate-jpa-2.0-api-1.0.0.Final.jar 2) 在实体类中添加JPA的标准注解 ...

  7. Hibernate @Formula 注解方式

    1.Formula的作用 Formula的作用就是用一个查询语句动态的生成一个类的属性 就是一条select count(*)...构成的虚拟列,而不是存储在数据库里的一个字段.用比较标准的说法就是: ...

  8. 2.2、Hibernate用注解方式实现一对多、多对多关系

    一.一对多关系 1.在上一篇日志中用.xml配置文件项目基础上,再往lib目录先添加一个包-hibernate-jpa-2.0-api-1.0.0.Final.jar 2.新建一个com.st.bea ...

  9. Hibernate用注解方式实现一对多、多对多关系

    一.一对多关系 1.在上一篇日志中用.xml配置文件项目基础上,再往lib目录先添加一个包-hibernate-jpa-2.0-api-1.0.0.Final.jar 2.新建一个com.st.bea ...

随机推荐

  1. linux 被入侵后扫尾工作

    比较恶心,安装了后门,还把ssh sshd 给改了,服务器在机房,还不大好处理,如果贸然上去改,还容易把自己关在外面. 但是我有salt ,上面可以用cmd.run运行一切命令.不走sshd服务. l ...

  2. 【雕爷学编程】Arduino动手做(46)---电阻应变片传感器

    37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...

  3. Python的第三方web开发框架Django

    1.Django Django是一个基于Python的第三方Web应用开发框架,可以简化Web开发. 官网:https://www.djangoproject.com/ 主要特点: ①采用MVC模型变 ...

  4. DRF认证组件

    1.DRF认证组件之视图注册用法(自定义简单使用) settings.py配置 INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.a ...

  5. Maven——pom.xml文件报错:Missing artifact:jar包

    原因:该错误原因为maven库中jar包无法更新 解决方法:找到maven库中对应的jar包路径,删除文件夹中的红框中的三个文件

  6. shiro认证通过之后的授权

    subject.hasRole("") ; subject.hasRoles(List); subject.hasAllRoles(); subject.isPermitted(& ...

  7. IO字节流与字符流的操作

    字节流:        FileInputStream读取,FileOutputStream输出 字节流使用数组缓冲区复制文件,最后得出所使用的时间 public class work2 { publ ...

  8. 记录我在Docker 中一步一步搭建Mysql 数据库存开发环境

    准备在docker下来搭建mysql开发环境玩玩,当作学习笔记.搭建环境是:win10 企业版,docker desktop 19.03.8,mysql 5.7,Windows PowerShell ...

  9. [安卓基础] 005.创建一个简单的UI

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  10. html5学习之路_003

    html布局 使用<div>元素布局 使用<table>元素布局 <div>元素布局 <!DOCTYPE html> <html> < ...