ejb3学习笔记4

1数据源: 详细定义

    <jndi-name>MSSQLDS</jndi-name>
    <connection-url>jdbc:sqlserver://localhost:1433;DatabaseName=EJB</connection-url>
    <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
    <user-name>sa</user-name>
    <password>123456</password>

 

2 配置实体bean

 

  1. @SuppressWarnings("serial")  
  2. @Entity  
  3. @Table(name="person")  
  4. public class Person implements Serializable{  
  5.       
  6.     private Integer id;  
  7.     private String name;  
  8.       
  9.     public Person(){  
  10.     }  
  11.       
  12.     public Person(String name){  
  13.         this.name = name;  
  14.     }  
  15.       
  16.     @Id @Column(name="id") @GeneratedValue(strategy=GenerationType.IDENTITY)  
  17.     public Integer getId() {  
  18.         return id;  
  19.     }  
  20.     public void setId(Integer id) {  
  21.         this.id = id;  
  22.     }  
  23.       
  24.     @Column(name="name", length=20, nullable=false)  
  25.     public String getName() {  
  26.         return name;  
  27.     }  
  28.     public void setName(String name) {  
  29.         this.name = name;  
  30.     }  
  31.       
  32.     @Override  
  33.     public int hashCode() {  
  34.         final int prime = 31;  
  35.         int result = 1;  
  36.         result = prime * result + ((id == null) ? 0 : id.hashCode());  
  37.         return result;  
  38.     }  
  39.     @Override  
  40.     public boolean equals(Object obj) {  
  41.         if (this == obj)  
  42.             return true;  
  43.         if (obj == null)  
  44.             return false;  
  45.         if (getClass() != obj.getClass())  
  46.             return false;  
  47.         final Person other = (Person) obj;  
  48.         if (id == null) {  
  49.             if (other.id != null)  
  50.                 return false;  
  51.         } else if (!id.equals(other.id))  
  52.             return false;  
  53.         return true;  
  54.     }  
  55.       
  56. }  

  

 

 

3 在jar META-INF 创建persistence.xml

 

  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <persistence xmlns="http://java.sun.com/xml/ns/persistence"  
  3.             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0">  
  5.     <persistence-unit name="itcast" transaction-type="JTA">  
  6.         <jta-data-source>java:MSSQLDS</jta-data-source>  
  7.         <properties>  
  8.             <property name="hibernate.hbm2ddl.auto" value="update"/>  
  9.             <property name="hibernate.show_sql" value="true"/>  
  10.             <property name="hibernate.format_sql" value="true"/>  
  11.         </properties>  
  12.     </persistence-unit>  
  13. </persistence>  

  

4 dao

 

  1. @Stateless  
  2. @Remote(PersonService.class)  
  3. public class PersonServiceBean implements PersonService{  
  4.     @PersistenceContext(unitName="itcast") EntityManager em;  
  5.       
  6.     public void delete(Integer personId) {  
  7.         em.remove(em.getReference(Person.class, personId));  
  8.         //返回而 代理对象   
  9.     }  
  10.   
  11.     public Person getPerson(Integer personId) {  
  12.         return em.find(Person.class, personId);  
  13.     }  
  14.   
  15.     @SuppressWarnings("unchecked")  
  16.     public List<Person> getPersons() {  
  17.         return (List<Person>) em.createQuery(" select p from Person p ").getResultList();  
  18.     }  
  19.   
  20.     public void save(Person person) {  
  21.         em.persist(person);  
  22.     }  
  23.   
  24.     public void update(Person person) {  
  25.         em.merge(person);  
  26.     }  
  27. }  

 

在dao 中:

@PersistenceContext(unitName="foshanshop") protected EntityManager em;

 

属性:

@Transient 实体bean默认全体成员都会持久, 该注释表示不持久某项

@Enumerated(EnumType.STRING)

public CommentType getType(){

}

 

public enum CommentType{

     NEWS{public String getName(){reutrn "新闻";}},

     PRODUCT{public String getName(){reutrn "产品";}};

     public abstract String getName();

}

 

@Lob 映射Blob  Clob

@Basic(fetch=FetchType.LAZY) 加在lob大文件时 延迟加载

@Temporal 指定时间类型

@Embedded

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值