摘要: 在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);
|