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

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

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

    posts - 17,  comments - 6,  trackbacks - 0
    在CMP實體BEAN中使用BLOB數(shù)據(jù)類型
    2005-07-19? ?來源:matrix.org.cn ?作者:matrix.org.cn
    摘要:
    在Oracle這樣的關(guān)系數(shù)據(jù)庫中,CLOB和BLOB類型被用來存放大對象。BOLB表示二進制大對象,這種數(shù)據(jù)類型通過用來保存圖片,圖象,視頻等。CLOB表示字符大對象,能夠存放大量基于字符的數(shù)據(jù)。JDBC定義java類型java.sql.Clob 和java.sql.Blob 對應數(shù)據(jù)庫中的CLOB和BLOB類型。然而這兩種類型并不能在實體BEAN中使用,因為這兩個類沒有被序列化(Serializable)。因此我們不能在CMP實體BEAN中定義java.sql.Clob或java.sql.Bl


    在Oracle這樣的關(guān)系數(shù)據(jù)庫中,CLOB和BLOB類型被用來存放大對象。BOLB表示二進制大對象,這種數(shù)據(jù)類型通過用來保存圖片,圖象,視頻等。CLOB表示字符大對象,能夠存放大量基于字符的數(shù)據(jù)。

    JDBC定義java類型java.sql.Clob 和java.sql.Blob 對應數(shù)據(jù)庫中的CLOB和BLOB類型。然而這兩種類型并不能在實體BEAN中使用,因為這兩個類沒有被序列化(Serializable)。因此我們不能在CMP實體BEAN中定義java.sql.Clob或java.sql.Blob這兩種數(shù)據(jù)類型。

    如果我們要使用數(shù)據(jù)庫的BLOB字段,我們必須在實體bean中聲明CMP字段為 byte[] 并映射該字段到數(shù)據(jù)庫的BLOB字段。如果要使用CLOB字段,我們需要使用定義CMP字段為 java.lang.String or char[] 。

    一個ENTITY的范例
    在一個企業(yè)里,處于安全考慮,我們也許要將員工的圖片保存到數(shù)據(jù)庫中的表里。這里我們使用EmployeePicture 作為范例來代表員工的圖片實體。這個EmployeePictureBean CMP有兩個屬性 empno, picture。 picture 字段被定義成byte[]型 。

    該EmployeePicture實體BEAN被映射到EMPPIC數(shù)據(jù)表, picture 屬性被映射為EMPPIC 表中的picture 字段,該picture字段是定義為BLOB類型的。

    下面是EmployeePictureBean.java的部分核心代碼:

    public abstract class EmployeePictureBean implements EntityBean
    {
    ? ....
    ? public abstract byte[] getPicture();
    ? public abstract void setPicture(byte[] newPicture);
    ? public Long ejbCreate(Long empno, byte[] newPicture)
    ? {
    ? ? setEmpno(empno);
    ? ? setPicture(newPicture);
    ? ? return empno;
    ? }

    ? public void ejbPostCreate(Long empno, byte[] newPicture)
    ? {
    ? }
    ? ...
    }


    如果我們使用OC4J 9.0.4 ,就需要在orion-ejb-jar.xml中定義實體BEAN屬性到數(shù)據(jù)表字段的映射。如果使用了其他J2EE容器,就需要在相關(guān)廠商的部署描述符中定義O-R映射。下面演示在OC4J中的映射代碼:

    <entity-deployment name="EmployeePicture" data-source="jdbc/OracleDS" table="EMPPIC">
    ? <primkey-mapping>
    ? ? <cmp-field-mapping name="empno" persistence-name="EMPNO" persistence-type="NUMBER(8)"/>
    ? </primkey-mapping>
    ? <cmp-field-mapping name="empno" persistence-name="EMPNO" persistence-type="NUMBER(8)"/>
    ? <cmp-field-mapping name="picture" persistence-name="PICTURE" persistence-type="BLOB"/>
    </entity-deployment>



    客戶端:
    CMP實體BEAN的客戶端沒有什么特別的處理。唯一需要注意的是在update數(shù)據(jù)表時要使用BufferedInputStream 來讀取IMAGE文件,但在檢索數(shù)據(jù)表時使用OutputStream 。

    下面演示如何讀取一個IMAGE文件,并創(chuàng)建一個BEAN實例:

     // Locate and open the file

    ? ? File imgFile = new File(fileName);

    ? ? long imgFileSize= imgFile.length();

    ? ? // initialize the byte array

    ? ? byte byteValue[] = new byte[(int)imgFileSize];

    ? ? // Read the file into the byte array

    ? ? InputStream is = new BufferedInputStream(new FileInputStream(imgFile));

    ? ? int len = is.read(byteValue);

    ? ? //Add the byte to the entity bean field

    ? ? if(len!=imgFileSize)

    ? ? {

    ? ? ? ? ? ?System.out.println("Read bytes did not equal file size on directory");

    ? ? }

    ? ? else

    ? ? {

    ? ? ? EmployeePictureLocal employeePicture = empHome.create(empNo , byteValue);

    posted on 2006-06-19 23:51 風中的舞者 閱讀(301) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導航:
     
    <2006年6月>
    28293031123
    45678910
    11121314151617
    18192021222324
    2526272829301
    2345678

    常用鏈接

    留言簿(1)

    隨筆檔案

    文章檔案

    java技術(shù)

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲国产精品无码久久久秋霞2| 国产亚洲精品观看91在线| 亚洲国模精品一区 | 亚洲av无码一区二区三区乱子伦 | 亚洲AV无码专区在线播放中文| 亚欧乱色国产精品免费视频| 免费在线观看h片| 午夜国产大片免费观看| 在线观看亚洲视频| 久久精品国产亚洲7777| 日本免费A级毛一片| 又粗又黄又猛又爽大片免费| 亚洲国产成人久久精品动漫| 美国毛片亚洲社区在线观看| 国产18禁黄网站免费观看| 一级看片免费视频囗交| 国产成人免费高清激情视频| 亚洲综合偷自成人网第页色| 在线视频免费观看www动漫| 亚洲精品免费在线视频| 久久精品成人免费观看97| 亚洲欧洲无码AV电影在线观看 | 四虎影视免费永久在线观看 | 亚洲国产精品成人精品小说| 啦啦啦在线免费视频| 色网站在线免费观看| 亚洲日产韩国一二三四区| 最近中文字幕无免费| 亚洲av综合av一区二区三区| 亚洲AV无码一区二区三区在线观看| 国产成人精品亚洲日本在线 | 2022久久国产精品免费热麻豆| 亚洲a级成人片在线观看| 免费吃奶摸下激烈视频| 黄色免费在线网站| 亚洲AV无码一区二区三区牛牛| 2022久久国产精品免费热麻豆| 亚洲国产AV一区二区三区四区| 夜夜春亚洲嫩草影院| 欧美大尺寸SUV免费| japanese色国产在线看免费|