Hibernate 註解方式
第一次接觸HIbernate都是以XML方式,今天來看看註解的方式如何寫
1. hibernate的常用註解
//標識實體類
@Entity
//該實體類對應的表 預設對應的表為類名 可通過@Table(name ="xxx")來標識實體類名與表名不同的情況
@Table
//實體類的標識屬性
@Id
//主鍵的生成策略
//strategy 生產策略有以下值
//GenerationType.AUTO 由程式控制 預設值
//GenerationType.IDENTITY 由資料庫生成
//GenerationType.SEQUENCE 由序列生成 需要資料庫支援
@GeneratedValue
//屬性對應的列 可通過@Column(name="xxx")來標識屬性和列名不同的情況
@Column
//設定一對一關聯
@OneToOne
//設定一對多關聯
@OneToMany
//設定多對一關聯
@ManyToOne
//設定多對多關聯
@ManyToMany
//設定外來鍵
@JoinColumn
//設定關聯表
@JoinTable
接下來寫一個簡單使用者類
2. User類
package pojo;
import javax.persistence.*;
/**
* Created by Administrator on 2018/10/29.
*/
@Entity
@Table(name = "customer")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
@Column(name="uname",length = 255,nullable = false,unique = true)
private String username;
@Column(name="name",length = 255)
private String nickname;
@Column(name="pword",length = 255,nullable = false)
private String password;
@Column(name = "age",nullable = false)
private int age;
@Column(name="address",unique = true)
private String address;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getNickname() {
return nickname;
}
public void setNickname(String nickname) {
this.nickname = nickname;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", nickname='" + nickname + '\'' +
", password='" + password + '\'' +
", age=" + age +
", address='" + address + '\'' +
'}';
}
}
3. hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 資料來源設定 -->
<property name="connection.url" >jdbc:mysql:///test</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username">root</property>
<property name="connection.password">root</property>
<!-- hibernate設定 -->
<property name="hbm2ddl.auto">update</property>
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<!-- xml方式 屬性使用resource -->
<!-- 註解方式 屬性使用class -->
<mapping class="pojo.User"/>
</session-factory>
</hibernate-configuration>
4. 測試
Main.java
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import pojo.User;
/**
* Created by Administrator on 2018/10/29.
*/
public class Main {
private static final SessionFactory ourSessionFactory;
static {
try {
Configuration configuration = new Configuration();
configuration.configure();
ourSessionFactory = configuration.buildSessionFactory();
} catch (Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static Session getSession() throws HibernateException {
return ourSessionFactory.openSession();
}
public static void main(final String[] args) throws Exception {
final Session session = getSession();
Transaction tx = session.beginTransaction();
User user = new User();
user.setUsername("mfsvejt");
user.setNickname("魔法少女厄加特");
user.setPassword("123456");
user.setAge(18);
user.setAddress("黃土高坡");
session.save(user);
tx.commit();
session.createQuery("from User").list().forEach(u -> System.out.println(u));
}
}
控制檯輸出
Hibernate:
create table customer (
id integer not null auto_increment,
address varchar(255),
age integer not null,
name varchar(255),
pword varchar(255) not null,
uname varchar(255) not null,
primary key (id)
) engine=InnoDB
Hibernate:
alter table customer
drop index UK_i0stw68u1778vsgy4idl3m183
Hibernate:
alter table customer
add constraint UK_i0stw68u1778vsgy4idl3m183 unique (address)
Hibernate:
alter table customer
drop index UK_dyi49bfteml6qub2etkw376y9
Hibernate:
alter table customer
add constraint UK_dyi49bfteml6qub2etkw376y9 unique (uname)
Hibernate:
insert
into
customer
(address, age, name, pword, uname)
values
(?, ?, ?, ?, ?)
十月 29, 2018 2:32:19 下午 org.hibernate.hql.internal.QueryTranslatorFactoryInitiator initiateService
INFO: HHH000397: Using ASTQueryTranslatorFactory
Hibernate:
select
user0_.id as id1_0_,
user0_.address as address2_0_,
user0_.age as age3_0_,
user0_.name as name4_0_,
user0_.pword as pword5_0_,
user0_.uname as uname6_0_
from
customer user0_
User{id=1, username='mfsvejt', nickname='魔法少女厄加特', password='123456', age=18, address='黃土高坡'}
可以看到我們的設定都成功了並且也輸出了魔法少女
,註解配置到此結束。
相關文章
- Hibernate中@Struct註解型別Struct型別
- Hibernate註解(一)之持久化實體持久化
- 手寫 Hibernate ORM 框架 01-註解常量定義ORM框架
- hibernate查詢的方式 都有哪些
- hibernate的三種查詢方式
- hibernate詳解
- springboot註解方式使用redis快取Spring BootRedis快取
- SpringBoot基於註解方式配置FilterSpring BootFilter
- hibernate詳解一
- spring boot使用註解的方式整合mybaitsSpring BootAI
- 3. 基於註解方式管理BeanBean
- spring通過註解註冊bean的方式+spring生命週期SpringBean
- Spring中基於註解方式的AOP操作Spring
- SpringBoot+Dubbo的註解方式整合例項Spring Boot
- 基於hibernate-validator實體欄位唯一性檢查 ,UniqueKey註解
- Spring學習筆記2(IOC註解方式&AOP)Spring筆記
- java-Mybatis 註解方式實現sql語句JavaMyBatisSQL
- 從Hessian RPC 註解方式看Spring依賴注入RPCSpring依賴注入
- Spring 實現策略模式--自定義註解方式解耦if...elseSpring模式解耦
- 註解式專案開發!詳細解析Java中各個註解的作用和使用方式Java
- spring-AOP(二)實現原理之AspectJ註解方式Spring
- Springboot+Aop註解的方式實現分散式鎖Spring Boot分散式
- Redis詳解 - SpringBoot整合Redis,RedisTemplate和註解兩種方式的使用RedisSpring Boot
- js 註冊事件的兩種方式詳解,傳統註冊事件與方法監聽註冊事件(addEventListener)JS事件dev
- 398、Java框架52 -【Hibernate - 分頁、兩種獲取方式】 2020.10.27Java框架
- Hibernate SQL方言 (hibernate.dialect)SQL
- 基於註解的方式使用spring-integration-redis分散式鎖SpringRedis分散式
- MyBatis 與 SpringBoot 整合:註解和xml兩種使用方式介紹MyBatisSpring BootXML
- 基於Springboot+Dubbo+Nacos 註解方式實現微服務呼叫Spring Boot微服務
- MyBatis從入門到精通(五):MyBatis 註解方式的基本用法MyBatis
- Hibernate
- 註解專題(一)Java元註解,內建註解Java
- JAVA-註解(2)-自定義註解及反射註解Java反射
- Spring系列之aAOP AOP是什麼?+xml方式實現aop+註解方式實現aopSpringXML
- Java註解-後設資料、註解分類、內建註解和自定義註解Java
- @ResponseBody註解和@RequestBody註解使用
- 【Spring註解】事務註解@TransactionalSpring
- Spring AOP整合redis(註解方式) 實現快取統一管理SpringRedis快取