EntityUtils

2024-03-07 18:39 更新

dorado服務端的數(shù)據(jù)處理提供了一個重要的工具類:EntityUtils。 在以下的幾種場景下我們可能會用到這個工具類。

獲取或設置數(shù)據(jù)的狀態(tài)

dorado支持批量數(shù)據(jù)提交功能: 我們可能在一個Grid中即做了新增,也做了修改刪除等各種操作,如果這些數(shù)據(jù)一次性的批量提交到后臺,我們希望在后臺的邏輯代碼中識別出這些記錄的修改狀態(tài)究竟是新增的還是刪除的還是修改的。這種情況下我們就可以通過EntityUtils工具類解決這個問題。

  1. @DataResolver
  2. @Transactional
  3. public void saveAll(Collection<Product> products) {
  4. for(Product product : products){
  5. if(EntityState.DELETED.equals(EntityUtils.getState(product))){
  6. System.out.println("刪除產品 : " + product.getProductName());//執(zhí)行產品刪除操作
  7. }
  8. else if(EntityState.MODIFIED.equals(EntityUtils.getState(product))){
  9. System.out.println("修改產品 : " + product.getProductName());//執(zhí)行產品修改操作
  10. }
  11. else if(EntityState.NEW .equals(EntityUtils.getState(product))){
  12. System.out.println("新增產品 : " + product.getProductName());//執(zhí)行產品新增操作
  13. }
  14. }
  15. //productDao.persistEntities(products);
  16. }

這是一段典型的代碼,前端提交了一個產品集合到后臺,后臺遍歷產品集合的時候可以通過EntityUtils的getState方法獲取到對象的狀態(tài),進而再交給業(yè)務邏輯層坐增刪改有區(qū)別的持久化處理。

獲取原始的數(shù)據(jù)對象

由于doardo為了維護記錄的數(shù)據(jù)狀態(tài),以及其它數(shù)據(jù)同步方面的原因,dorado對提交到java后臺的數(shù)據(jù)進行了cglib的代理處理,為了獲取被代理的原始對象,我們可以通過EntityUtils解決這個問題,參考代碼:

  1. @DataResolver
  2. @Transactional
  3. public void saveAll(Collection<Product> products) throws Exception {
  4. for (Product product : products) {
  5. Product sourceProduct = EntityUtils.toPureData(product);
  6. if (EntityState.DELETED.equals(EntityUtils.getState(product))) {
  7. System.out.println("刪除產品 : " + sourceProduct.getProductName());// 執(zhí)行產品刪除操作
  8. } else if (EntityState.MODIFIED.equals(EntityUtils.getState(product))) {
  9. System.out.println("修改產品 : " + sourceProduct.getProductName());// 執(zhí)行產品修改操作
  10. } else if (EntityState.NEW.equals(EntityUtils.getState(product))) {
  11. System.out.println("新增產品 : " + sourceProduct.getProductName());// 執(zhí)行產品新增操作
  12. }
  13. }
  14. productDao.persistEntities(products);
  15. }

我們可以通過這行代碼獲取到原始的Product對象:

  1. Product sourceProduct = EntityUtils.toPureData(product);

虛擬屬性的存取

如果我們希望給業(yè)務數(shù)據(jù)對象添加一個POJO中不存在的新的屬性,同時又不想改變POJO的結構,那么我們就可以通過EntityUtils工具類做到:

  1. @DataProvider
  2. public Collection<MockCategory> getCategories() throws Exception {
  3. Collection<MockCategory> categories = generateCategories();
  4. categories = EntityUtils.toEntity(categories);
  5. for (MockCategory category : categories) {
  6. EntityUtils.setValue(category, "categoryName", "CategoryName "
  7. + category.getId());
  8. }
  9. return categories;
  10. }

上面的代碼就是給MockCagegory對象添加了一個categoryName屬性,并設置了一個值。 通過虛擬屬性我們可以避免修改POJO對象,或創(chuàng)建新的VO對象。 設置虛擬屬性之前要確保操作的是一個被代理的數(shù)據(jù)對象,如果是業(yè)務邏輯層或持久層拿到的原始業(yè)務數(shù)據(jù)對象,我們用通過EntityUtils.toEntity(object)函數(shù)實現(xiàn)轉換,這個函數(shù)即支持單個數(shù)據(jù)對象,也支持集合類型的數(shù)據(jù)對象。

當我們對數(shù)據(jù)對象添加了虛擬屬性值后,我們還可以通過EntityUtils工具類獲取虛擬屬性的值。

  1. @DataProvider
  2. public Collection<MockCategory> getCategories() throws Exception {
  3. Collection<MockCategory> categories = generateCategories();
  4. categories = EntityUtils.toEntity(categories);
  5. for (MockCategory category : categories) {
  6. EntityUtils.setValue(category, "categoryName", "CategoryName "
  7. + category.getId());
  8. }
  9. for (MockCategory category : categories) {
  10. String value = (String)EntityUtils.getValue(category, "categoryName");
  11. }
  12. return categories;
  13. }

通過EntityUtils的getValue方法可以獲取虛擬屬性的值,當然這個方法對數(shù)據(jù)對象本身的屬性值的獲取也是支持的,例如:

  1. Long id = (Long)EntityUtils.getValue(category, "id");

上面的代碼我們用了強制類型轉換,事實上如果能預先確認數(shù)據(jù)類型的話,你也可以直接用別的接口函數(shù)代替:

  1. Long id = EntityUtils.getLong(category, "id");
以上內容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號