<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    love fish大鵬一曰同風起,扶搖直上九萬里

    常用鏈接

    統計

    積分與排名

    friends

    link

    最新評論

    EJB 3.0開發指南之使用實體Bean

     在上面一個例子中,實體Bean的屬性對應到數據表中的列,都是采用默認的設置。通過Column,你可以為屬性指定數據表中的列名。
    Column的聲明如下:

    @Target({TYPE, METHOD, FIELD}) @Retention(RUNTIME)
    public @interface Column {
     String name() default "";
     boolean primaryKey() default false;
     boolean unique() default false;
     boolean nullable() default true;
     boolean insertable() default true;
     boolean updatable() default true;
     String columnDefinition() default "";
     String secondaryTable() default "";
     int length() default 255;
     int precision() default 0;
     int scale() default 0;
     boolean specified() default true; // For internal use only
    }

      EntityManager 是用來處理實體Bean的輔助類。它可以用來產生/刪除持久化的實體Bean,通過主鍵查找實體bean,通過查詢語言來查詢實體Bean。

      下面是EntityManager接口的聲明:

    package javax.ejb;

    import java.sql.Connection;
    /**
    * 用來和持久化上下文交互的接口
    */

    public interface EntityManager {

     /**
     * 使實體bean受持久化管理
     * @param entity
     */

     public void create(Object entity);
     
     /**
     * 將給定的實體Bean的狀態和持久化上下文結合。類似數據庫的更新操作。
     * @param entity
     * @return 被結合的實體實例
     */

     public <T> T merge(T entity);

     /**
     * 刪除實例
     * @param entity
     */

     public void remove(Object entity);
     /**
     * 根據主鍵查找.
     * @param entityName
     * @param primaryKey
     * @return 查詢實例
     */

     public Object find(String entityName, Object primaryKey);
     /**
     * 根據主鍵查找
     * @param primaryKey
     * @return 查詢實例
     */

     public <T> T find(Class<T> entityClass, Object primaryKey);
     /**
     * 持久化上下文與底層數據庫的同步
     */

     public void flush();
     /**
     * 執行一個EJBQL查詢
     * @param ejbqlString EJBQL查詢語句
     * @return the new query instance
     */

     public Query createQuery(String ejbqlString);
     /**
     * 執行命名的查詢
     * @param name 預定義的查詢名稱
     * @return 查詢實例
     */

     public Query createNamedQuery(String name);
     /**
     * 執行一個本地SQL查詢語句
     * @param sqlString 本地查詢語句
     * @return 返回查詢實例
     */

     public Query createNativeQuery(String sqlString);
     /**
     * 更新到數據庫中
     * @param entity
     */

     public void refresh(Object entity);
     /**
     * 持久化上下文中刪除實體
     * @param entity
     */

     public void evict(Object entity);
     /**
     * 檢查當前上下文中是否包含此實體
     * context.
     * @param entity
     * @return
     */

     public boolean contains(Object entity);
    }

      @JoinColumns

      用來指示符合主鍵,在后面的章節中介紹。

       這個例子主要有以下幾個文件,這個例子主要實現了管理學生分數的功能。Student是一個實體Bean,管理學生的基本信息(姓名和各課分數),其中學生的分數又是一個實體Bean。TacherBean是一個無狀態的會話Bean,用來調用實體Bean。和前面的例子一樣,我們還是使用Client測試。

      ·Student.java:實體Bean。

      ·Score.java:實體Bean。

      ·Teacher.java:會話Bean的業務接口

      ·TeacherBean.java:會話Bean的實現類

      ·Client.java:測試EJB的客戶端類。

      ·jndi.properties:jndi屬性文件,提供訪問jdni的基本配置屬性。

      ·Build.xml:ant 配置文件,用以編譯、發布、測試、清除EJB。

      下面針對每個文件的內容做一個介紹。

      Student.java

    package com.kuaff.ejb3.entity;

    import javax.ejb.CascadeType;
    import javax.ejb.Entity;
    import javax.ejb.FetchType;
    import javax.ejb.GeneratorType;
    import javax.ejb.Id;
    import javax.ejb.JoinColumn;
    import javax.ejb.OneToMany;
    import javax.ejb.Table;
    import java.util.ArrayList;
    import java.util.Collection;
    import java.io.Serializable;

    @Entity
    @Table(name = "STUDENT")

    public class Student implements Serializable
    {
     //主鍵
     private int id;
     //學生名
     private String name;
     //學生的分數
     private Collection<Score> scores;
     //主鍵自動產生

     @Id(generate = GeneratorType.AUTO)

     public int getId()
     {
      return id;
     }

     public void setId(int id)
     {
      this.id = id;
     }

     public String getName()
     {
      return name;
     }

     public void setName(String name)
     {
      this.name = name;
     }

     public void addScores(String name,int number)
     {
      if (scores == null)
      {
       scores = new ArrayList<Score>();
      }
      Score score = new Score();
      score.setName(name);
      score.setNumber(number);
      score.setStudent(this);
      scores.add(score);
     }

     @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
     @JoinColumn(name = "student_id")

     public Collection<Score> getScores()
     {
      return scores;
     }

     public void setScores(Collection<Score> scores)
     {
      this.scores = scores;
     }
    }

      Student.java實現了Student實體Bean,它提供學生的基本情況以及學生的得分情況,得分是另外一個實體Bean。Student實體Bean和Score實體Bean是一對多的關系,站在Score的角度看是多對一的關系。

      實體Bean需要使用@Entity做注釋,另外它指定這個實體Bean與表STUDENT對應(通過注釋@Table(name = "STUDENT")),你可以在JBOSS的數據庫中看到這個表。

      Score.java

    package com.kuaff.ejb3.entity;

    import java.io.Serializable;
    import javax.ejb.Entity;
    import javax.ejb.GeneratorType;
    import javax.ejb.Id;
    import javax.ejb.JoinColumn;
    import javax.ejb.ManyToOne;
    import javax.ejb.Table;

    @Entity
    @Table(name = "Score")

    public class Score implements Serializable
    {
     private int id;
     private String name;
     private int number;
     private Student student;

     //主鍵自動產生

     @Id(generate = GeneratorType.AUTO)

     public int getId()
     {
      return id;
     }

     public void setId(int id)
     {
      this.id = id;
     }

     public String getName()
     {
      return name;
     }

     public void setName(String name)
     {
      this.name = name;
     }

     public int getNumber()
     {
      return number;
     }

     public void setNumber(int number)
     {
      this.number = number;
     }

     @ManyToOne
     @JoinColumn(name = "student_id")

     public Student getStudent()
     {
      return student;
     }

     public void setStudent(Student student)
     {
      this.student = student;
     }

    }

      這個實體Bean存放學生的分數。

      Teacher.java

    package com.kuaff.ejb3.entity;



    import javax.ejb.Remote;

    import javax.ejb.Remove;

    import java.util.Map;



    @Remote

    public interface Teacher

    {

    public void addScore(String studentName,Map<String,Integer> map);



    public Student getStudent();



    @Remove

    public void leave();

    }

      這個會話Bean接口提供增加分數和得到用戶的方法。

      TeacherBean.java

    package com.kuaff.ejb3.entity;

    import javax.ejb.EntityManager;
    import javax.ejb.Inject;
    import javax.ejb.Remove;
    import javax.ejb.Stateful;
    import java.util.Map;
    import java.util.Set;

    @Stateful

    public class TeacherBean implements Teacher
    {
     @Inject
     private EntityManager manager;
     private Student student;

     public Student getStudent()
     {
      return student;
     }

     public void addScore(String studentName, Map<String,Integer> map)
     {
      if (student == null)
      {
       student = new Student();
      }
      student.setName(studentName);
      Set<String> set = map.keySet();
      for (String sname:set)
      {
       student.addScores(sname,map.get(sname).intValue());
      }
     }

     @Remove

     public void leave()
     {
      manager.create(student);
     }



    }

      這個是會話Bean的實現類。

      Client.java

    package com.kuaff.ejb3.entity;

    import java.util.Map;
    import java.util.HashMap;
    import java.util.Collection;
    import javax.naming.InitialContext;
    import javax.naming.NamingException;

    public class Client
    {
     public static void main(String[] args) throws NamingException
     {
      InitialContext ctx = new InitialContext();
      Teacher teacher = (Teacher) ctx.lookup(Teacher.class.getName());
      Map<String,Integer> map = new HashMap<String,Integer>();
      map.put("語文",new Integer(98));
      map.put("化學",new Integer(149));
      map.put("物理",new Integer(143));
      teacher.addScore("smallnest",map);
      Student student = teacher.getStudent();
      String name = student.getName();
      System.out.printf("顯示%s的分數:%n",name);
      Collection<Score> c = student.getScores();

      for (Score score:c)
      {
       System.out.printf("%s:%s%n",score.getName(),score.getNumber()+"");
      }
     }
    }

      這個客戶端增加學生的分數,并且測試顯示這個學生的相關信息。

      請運行{$JBOSS_HOME}/bin目錄下的run.bat: run –c all,啟動JBOSS。

    http://localhost:8080/jmx-console/HtmlAdaptor?action=inspectMBean&name=jboss%3Aservice%3DHypersonic%2Cdatabase%3DlocalDB,然后調用startDatabaseManager()方法,打開HSQL管理工具管理數據庫。

      在Eclipse的Ant視圖中執行ejbjar target。或者在命令行下,進入到此工程目錄下,執行ant ejbjar,將編譯打包發布此EJB。

      在Eclipse的Ant視圖中執行run target。或者在命令行下,進入到此工程目錄下,執行ant run,測試這個EJB。

    posted on 2006-07-04 09:25 liaojiyong 閱讀(498) 評論(2)  編輯  收藏 所屬分類: EJB

    評論

    # re: EJB 3.0開發指南之使用實體Bean 2006-07-05 15:54 xq

    夠勁  回復  更多評論   

    # re: EJB 3.0開發指南之使用實體Bean 2006-07-05 19:16 liaojiyong

    中!  回復  更多評論   

    主站蜘蛛池模板: 最新亚洲人成网站在线观看| 亚洲乱码一区二区三区国产精品| 一区二区免费国产在线观看| 日韩免费电影在线观看| 亚洲人成网站在线播放2019| 免费网站看v片在线香蕉| 亚洲av乱码中文一区二区三区| 国产成人无码区免费A∨视频网站 国产成人涩涩涩视频在线观看免费 | 国产一区二区三区在线免费 | 久久精品国产亚洲AV蜜臀色欲| 色影音免费色资源| 亚洲乱码一二三四区乱码| 性感美女视频免费网站午夜| 色婷婷亚洲一区二区三区| 深夜国产福利99亚洲视频| 精品国产福利尤物免费| 亚洲VA中文字幕无码一二三区 | a级毛片黄免费a级毛片| 久久久国产精品亚洲一区| 精品国产免费人成电影在线观看| 亚洲一区中文字幕在线电影网| 免费看美女让人桶尿口| sss在线观看免费高清| 亚洲av无码一区二区三区网站| 亚洲一级毛片免费看| 久久久亚洲精华液精华液精华液| 亚洲一本大道无码av天堂| 国产免费AV片在线观看| 亚洲卡一卡二卡乱码新区| 亚洲精品乱码久久久久久蜜桃| 免费A级毛片无码视频| 亚洲成a人无码亚洲成www牛牛| 狠狠亚洲狠狠欧洲2019| 麻豆国产精品免费视频| 黄人成a动漫片免费网站| 香蕉蕉亚亚洲aav综合| 暖暖日本免费在线视频| 久久久久成人片免费观看蜜芽 | 啦啦啦高清视频在线观看免费 | 羞羞漫画页面免费入口欢迎你| 亚洲v高清理论电影|