Eva
Java粉絲募集中
  • 簡介
  • 我們的優勢
  • 最新消息
  • 下載與使用
  • 範例與說明
    • Eva Objects >
      • Bean類別定義
      • Entity型別定義
      • Struct型別定義
      • 建立Entity空白物件
      • 建立Entity修改物件
      • 建立Entity條件物件
      • 建立Struct值物件
    • Eva_ORM >
      • ORM程式主體
      • 使用條件物件執行操作
      • 執行更複雜條件的操作.
      • 分頁取回資料
      • 操作JDBC的參數
      • Array Property的操作
      • Collection Property的操作
      • 更複雜的Collection Property
      • 指定表格名稱
      • 新增資料庫Dialect
    • Eva_IOC >
      • IOC程式主體
      • AOP應用
    • Eva_Struct >
      • Struct範例
      • Bit Strcut範例
      • 指標範例
      • 於Eva_ORM中使用
    • Eva_Sort >
      • 依指定Properties排序
      • 部份排序
      • 優先排序部份
    • Eva_Cache >
      • hashing-based cache
      • 非hashing-based cache
  • API列表
  • 技術支援
    • 協助開發
  • 相關書籍

ORM程式主體.

在下面範例中, 定義了一個Entity X. 而在稍後的程式中, 對於X型別的物件的所做的增刪改查, 多是透過ORMappers介面中的相關方法去完成, 而且所有的方法需在open()與close()的區間內才能被執行. 還有需注意的是, 一個Entity需被@Entity Annotation所標記才能被Eva_ORM識別. 另外, 在這裡透過了DefaultTableCreator類別去建立測試用的資料表, 這樣可以忽略很多的待設定事項, 但對於正式的環境, 應先使用資料表schema的圖形建立工具去建立schema, 再透過資料庫提供的管理介面, 去進行表格的建立.
package com.logntw.eva.orm.defo;

import java.util.List;

import junit.framework.Assert;

import org.junit.Test;

import com.logntw.eva.anno.orm.Entity;
import com.logntw.eva.anno.orm.Id;
import com.logntw.eva.orm.ConverterUtil;
import com.logntw.eva.orm.EagerToGet;
import com.logntw.eva.orm.EntityUtil;
import com.logntw.eva.orm.ORMappers;
import com.logntw.eva.orm.DBConnectionProvider;
import com.logntw.eva.orm.defo.conn.HSQLDB_1_8ConnectionProvider;

public class DefoORMappersTest5
{
  @Entity
  public interface X
  {
    @Id
    int getId1();
    void setId1(int id1);
        
    int getData1();
    void setData1(int data1);  
    
    @Id
    Y getId2();
    void setId2(Y id2);
        
    Y getData2();
    void setData2(Y data2);
  }
  
  @Entity
  public interface Y
  {
    @Id
    double getId3();
    void setId3(double id3);

    @Id
    double getId4();
    void setId4(double id4);
              
    String getData3();
    void setData3(String data3);
  }
  
  @Test
  public void testResultSetAccessorImpRead() throws Exception
  {            
    DBConnectionProvider provider = new HSQLDB_1_8ConnectionProvider("DefoORMappersTest5");    
    ORMappers mappers = DefoORMappers.getInstance(provider);

    DefaultTableCreator.create(mappers, Y.class);
    DefaultTableCreator.create(mappers, X.class);
    
    mappers.open();

    try
    {      
      Y y1 = mappers.newObject(Y.class);
      
      y1.setId3(10);
      y1.setId4(22.2f);
      y1.setData3("abc");
      
      Y y2 = mappers.newObject(Y.class);
      
      y2.setId3(30);
      y2.setId4(33.3f);
      y2.setData3("def");

      X x1 = mappers.newObject(X.class);
      x1.setId1(99);
      x1.setId2(y1);
      x1.setData1(77);
      x1.setData2(y2);
      
      
      mappers.insert(y1, y2);
      mappers.insert(x1);
      
      List<X> list = mappers.select(EagerToGet.ENTITY, X.class);
      Assert.assertEquals(list.size(), 1);
                
      X x3 = list.get(0);
      Assert.assertEquals(x1, x3);        
      
      mappers.getMapper(X.class).deleteAll();
      mappers.getMapper(Y.class).deleteAll();
      
      list = mappers.select(EagerToGet.ENTITY, X.class);
      Assert.assertEquals(list.size(),0);
      List<Y> list3 = mappers.select(EagerToGet.ENTITY, Y.class);
      Assert.assertEquals(list3.size(),0);      
    }
    finally
    {      
      mappers.close();
      DefaultTableCreator.drop(mappers, X.class);
      DefaultTableCreator.drop(mappers, Y.class);      
    }  
  }
}
Powered by Create your own unique website with customizable templates.