亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

關于Java數據對象JDO 2.0查詢語言的特點

2019-11-17 04:59:24
字體:
來源:轉載
供稿:網友
查詢語言的改進是JDO2.0規范中的重要環節,本文從較高的層面闡述JDO2.0所提供的一些新功能。由于JDO2.0規范還未進入公開草案狀態,目前還沒有任何內容敲定下來,一切都還可能面臨變化。不過,JDO2.0將會很快進入最后階段,而這里提到的查詢特性是JDO2.0專家組(譯者注: David Jordan就是專家組重要成員)花費時間最多,并且相對來說最為穩定。因此,我有足夠理由相信,最終規范與這里的描述將會基本一致。

  如果各位讀者覺得本文遺漏了某些重要的特性,建議立即到JDO論壇(http://www.jdocentral.com/forums/index.php?showforum=10 )去提出并討論。這里我們需要感謝JDO2.0規范領導人Craig Russell授權給我公開這些JDO2.0查詢語言的新特性。

  查詢結果

  我們首先從最深入的改進開始介紹。在JDO1.0中,查詢結果總是你所指定的類的實例集合。考慮下面的UML類圖,它表達了A、B、C、D四個類及之間的關系:

  你可以創建一個對A類的查詢,通過contains()引用到B類,再通過又一層contains()引用到C類,最后再使用一個“.”操作符引用到D 類。但最終返回的集合中只會包含A類的對象實例,如果要從結果中獲得其它類,就必須通過A類的引用來逐個獲取相關的其它類對象。如果你的查詢條件里面包含了B、C或D類的約束,那么在結果集中通過A類對象引用其它類對象時,必須重新將這些約束在java代碼中重復一遍,也就是說,你不得不在Java和JDOQL中重復聲明限制條件。再者,你可能只關心滿足查詢條件的D類對象,而不希望中間的B、C類對象被JDO底層創建從而節省內存或相關資源。

  在JDO2.0中,你再也不受縛于這些限制了。你可以返回:

  數據類(PersistentCapable)的一個或多個字段
  候選類以外的其它類對象
  統計數據

  這意味著你可以返回A、B、C、D類對象,或者它們的某些字段,或者二者的混和結果。你還可以計算類似min或max之類的統計結果。基本上,你想返回什么結果都可以。

  當你創建一個查詢時,你可以指定一個“結果定義(Result Specification)”來指定返回什么樣的內容。它是一個包含一個或多個以逗號分隔的“結果表達式(Result ExPRession)”。結果表達式可以是:

  this關鍵字,表示返回候選類的對象實例。這與JDO1.0是一樣的字段,標明候選類或引用類的某個字段的值,如 address.street.name 字段表達式,代表對多個字段進行JDO預定義的幾種算術運算而獲得的結果變量,代表查詢條件中出現的某個中間變量引用表達式,也就是JDO1.0中的通過 “.”操作符進行的對象之間的引用 統計表達式通過對以上這幾種結果表達式的組合運用,你可以獲得任何你想要的結果。

  JDO2.0支持下面的統計函數:

  count(表達式),表達式可以是this
  sum(數字型字段表達式),“數字型字段表達式”可以是通過字段或字段的運算得到的數字型的結果
  min(數字型字段表達式)
  max(數字型字段表達式)
  avg(數字型字段表達式)

  對查詢結果的指定是通過下面的API:

void javax.jdo.Query.setResult(String result)


  如果你不調用這個方法,或者參數是null,則返回候選類的對象實例(相當于設置為“this”),即JDO1.0的返回結果。如果你只指定了唯一結果表達式,則返回集合的元素類型與該結果的類型一致。另外,在默認方式下,如果指定了多個結果表達式,則返回的集合元素類型將是 Object[]。

  你可以在結果定義字符串的開頭標上distinct來保證結果不會重復。而如果結果定義串中包含好幾個表達式,那么distinct可以保證結果集中不會有重復的數據組。

  每個結果表達式可以指定一個名稱,對于簡單的字段,系統會默認以該字段的名稱作為結果中該項的名稱。對復雜的表達式,你可以使用下面的語法指定名稱:

result_expression as name

  
  名稱的使用可以讓結果中的該項作為結果類中的一個屬性來進行設置和使用。你可以指定一個結果類(result class),用來返回查詢結果。如果查詢結果是一個單值,結果類可以是任何JDO支持的類(Integer, Double, String, BigInteger, BigDecimal, java.util.Date, java.sql.Date, java.sql.Time, java.sql.Timestamp)。Query中設置結果類的方法是:

void setResultClass(Class resultClass)


  如果查詢結果包含多個結果表達式,你可以定義一個結果類來保留結果中的各項數據,這個類必須有一個無參數的構造器。此外,每個結果表達式必須對應此類中的一個屬性,不論是一個public的字段,還是一個public的setXxx()方法,并且這種直接的或bean風格的屬性名稱與查詢結果中各項結果表達式的名稱保持一致。

    組操作(Grouping)

  統計功能可用于一個分組操作中。JDO2.0提供類似SQL中的GROUP BY和HAVING子句。Query方法:

void setGrouping(String groupSpec)

  用于指定分組的原則。groupSpec參數包含一個或多個以逗號分隔的分組表達式,還可以跟上一個以“having ”開頭的過濾條件。調用此方法后,setResult()參數的每個結果表達式項必須是groupSpec中的一項,或者是groupSpec中的一項或多項的運算結果。所有groupSpec項的值均相同的結果被歸在同一組中(同一條結果記錄)。having子句的過濾條件可以包含boolean結果的判斷語句或者是對分組表達式的統計運算。與SQL一樣,having子句用于對分組后的結果集進行條件過濾。

  唯一性(Uniqueness)

  很多人一直奇怪為什么Query的執行(execute)結果是一個Object類型的對象,因為這樣給開發人員造成必須手工強制將結果轉換成Collection的不便。JDO1.0中查詢結果一般有多個元素,但JDO專家組計劃在JDO2.0中加入對返回單值結果的查詢的支持,于是將Query的執行結果定義為Object類型。

  你有時會執行一個你確定結果只會有一條的查詢(比如統計總數或者按具有唯一索引的會員帳號查找對象等等),在JDO2.0中,你可以調用Query方法來聲明:

void setUnique(boolean unique)

  當你傳入“true”后,Query執行的結果將是一個單獨的值對象,如果無任何結果返回,則結果是null。如果JDO發現查詢結果返回了多條記錄,則會扔出一個異常。

  限制返回結果的大小

  設計用戶界面的時候,我們常常會顯示結果集的某一部分子集(比如分頁顯示或只顯示前十條之類)。為了性能和效率,你多半會需要限制返回結果的范圍。Query的方法可以完成這一點:

void setRange(int fromInclusive, int toExclusive)

  該方法返回的結果集只包含原結果集的第fromInclusive條到第toExclusive-1條。

  新的過濾條件操作符

  一些新的操作符被加到JDOQL中,以便執行針對引用、Map、字符串和數字的操作。instanceof操作符返回一個boolean值,可以讓你過濾某個指定類的對象;同樣返回boolean值的containsKey(Object)函數和containsValue(Object)用于訪問 Map元素。

  字符串處理方面加入了很多函數,toLowerCase()和toUpperCase()分別完成大小寫轉換,另外還有下列函數用于查找子串位置和獲得子串:

int indexOf(String)
int indexOf(String, int) String substring(int) String substring(int,int)

  另外,String的方法:

boolean matches(String pattern)

  用于執行正則式匹配。目前只能提供有限的匹配功能。“.”和“.*”可表示通配符,而“(?i)”表示匹配不區分大小寫。

  對數字型的字段,JDO2.0增加了兩個函數:

Math.abs(numeric) Math.sqrt(numeric)

  預定義查詢(Named Queries)

  你可以在JDO描述符(metadata)中聲明常用的JDOQL查詢語句,這樣就不用將查詢嵌入到Java源代碼中。這樣可以提供一些靈活性,比如將查詢語句寫到一個配置好的文本文件中,而需要修改時可以直接改該文件,而不用更改Java源碼。描述符中的每個查詢都有一個名字,而要執行某個查詢時,可以使用下面的方法來創建查詢:

Query newNamedQuery(Class cls, String queryName)

  JDO將會搜索描述符來找到對應的預定義查詢語句并生成相應的Query對象。

  訪問靜態字段(static fields)

  你將可以在JDOQL中訪問數據類中以public static final方式聲明的常量。比如

public static final int FEMALE = 0;
public static final int MALE = 1;
public static final int UNKNOWN = 2;

  而在查詢中使用類似“salary > 5000.0 && gender == MALE”的過濾條件。

  批量刪除(Deletion by Query)

  在JDO1.0中,要刪除一個對象,必須先將其載入內存,再刪除,然而很多情況下,你在刪除之前并不需要訪問該對象,這樣的做法比較低效。在JDO2.0中,提供了Query的幾個方法來刪除符合查詢條件的一組對象:

Object deletePersistentAll(Object[] parameters) Object deletePersistentAll(Map parameters) Object deletePersistentAll()

  此查詢結果的對象會被全部從數據庫刪除。這些方法返回被刪除對象的集合。你的程序可以決定是否需要對被刪除的對象逐個訪問。如果你不訪問這些對象,Query執行的性能將不會受到任何影響,換句話說,這些對象將不會在內存中生成。

    廠商擴展的查詢特性

  JDO廠商可以給JDOQL提供各種各樣的特殊查詢功能。每個廠商可以定義一組屬于該廠商自己的擴展功能。如果你需要使用其中的功能,你需要將該廠商的擴展加到程序運行環境中。每個擴展有一個名字和一個可選的值。你可以單獨設置每個擴展,或者一次性設置多個擴展。Query的下列方法用于設置廠商擴展特性:

void setExtensions(Map extensions) void addExtension(String key, Object value)

  SQL直接訪問

  如果JDO2.0的查詢功能不能滿足需要,并且以下條件都滿足:

  你的應用運行在關系數據庫上
  
  你需要的查詢有SQL語句可以實現

  你知道從你的類模型到數據庫的映射細節

  你就可以創建一個SQL查詢,方法是調用PersistentManger的方法:

Query newQuery(String language, Object query)
  
  每一個參數需要設置為“javax.jdo.query.SQL”,而query是一個具體的SQL語句。如果你的查詢需要返回類的實例,則這個SQL語句必須返回該類的相應主鍵字段。使用直接的SQL時,JDOQL提供的函數將不能被使用,否則將會扔出異常JDOUserException,比如,你不能對該Query設置過濾條件字符串、排序聲明或變量聲明。使用 SQL查詢時,參數都是未指定類型的,在SQL語句中以“?”表示,并且按出現的順序被綁定。

  結束語

  各位讀者已經看到,JDO2.0對查詢語句增加了很多新的功能和特性,我認為其中的查詢結果定義是最大的改進。正如我在文章開頭說的,這一部分變化目前來說是JDO2.0中最穩定的部分,不會有大的變化。廠商可以開始提供很多這樣的功能,不用考慮專家組還在討論的JDO2.0其余部分將如何變化。

  在JDO2.0提供標準的對象/關系映射的前提下,這里描述的查詢功能和一個用于多層結構的JDO應用的脫鉤/掛鉤(detach/attach)機制,將使JDO占領更多的市場。對這一點有深切體會的廠商將不遺余力地爭取率先推出穩定、完整、高效的JDO2.0產品。JDO將是基于數據庫存儲和管理的應用開發的首先API,開發人員們將享受面向對象的模型設計和高效的數據存儲管理系統。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美视频一区二区三区…| 亚洲精品美女网站| 久久精品精品电影网| 日韩在线观看免费全| 欧美午夜片欧美片在线观看| 日本一区二区在线播放| 欧美又大又硬又粗bbbbb| 最近2019中文免费高清视频观看www99| 日韩在线视频观看正片免费网站| 欧美激情网友自拍| 91亚洲永久免费精品| 日韩欧美有码在线| 久久精品国产v日韩v亚洲| 91精品国产色综合久久不卡98口| 另类专区欧美制服同性| 日本亚洲精品在线观看| 全亚洲最色的网站在线观看| 国产精品美女午夜av| 国产欧美日韩精品丝袜高跟鞋| 中文字幕亚洲一区二区三区五十路| 精品一区精品二区| 亚洲国产精品小视频| 黑人精品xxx一区| 在线日韩中文字幕| 国产日产欧美精品| 91久久久久久久一区二区| 国产精品一区二区三区毛片淫片| 九九热这里只有在线精品视| 午夜美女久久久久爽久久| 久久精品国产一区| 国产一区二区免费| 欧美视频在线观看 亚洲欧| 裸体女人亚洲精品一区| 在线精品播放av| 亚洲国产高清福利视频| 欧美激情按摩在线| 日韩在线视频网站| 深夜福利91大全| 欧美巨猛xxxx猛交黑人97人| 亚洲国产精品国自产拍av秋霞| 成人免费观看网址| 欧美黄色三级网站| 欧美在线观看网址综合| 亚洲的天堂在线中文字幕| 色婷婷综合成人av| 日本高清视频精品| 最近2019中文字幕一页二页| 欧美激情手机在线视频| 午夜精品久久久久久久久久久久久| 久久久精品亚洲| 国产男女猛烈无遮挡91| 欧美人与物videos| 粉嫩老牛aⅴ一区二区三区| 欧美黄色免费网站| 国产精品久久久久久av| 日韩精品免费综合视频在线播放| 久久久久久久97| 亚洲欧美一区二区三区情侣bbw| 久久久这里只有精品视频| 国产精品女主播| 亚洲综合色av| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产亚洲欧美日韩一区二区| 亚洲大尺度美女在线| 国产欧美va欧美va香蕉在线| 欧美日韩国产丝袜另类| 欧美性猛交xxxx富婆| 欧美国产亚洲精品久久久8v| 美女性感视频久久久| 久久精品中文字幕免费mv| 亚洲深夜福利在线| 日韩欧美在线视频免费观看| 亚洲精品美女久久久| 欧美日韩激情网| 亚洲专区中文字幕| 国外成人性视频| 欧美巨乳美女视频| 亚洲精品国精品久久99热| 欧美成人精品影院| 92看片淫黄大片欧美看国产片| 久久精品2019中文字幕| 色综久久综合桃花网| 久久免费国产视频| 国产情人节一区| 国产精品入口日韩视频大尺度| 久久久精品在线观看| 亚洲视频网站在线观看| 欧美视频专区一二在线观看| 欧美日韩国产一区在线| 亚洲国产精品人人爽夜夜爽| 97视频在线看| 日韩欧美在线视频日韩欧美在线视频| 亚洲男人天堂2024| 亚洲人成在线免费观看| 日韩av影片在线观看| 日韩av最新在线| 成人精品视频99在线观看免费| 国产91|九色| 国内精品小视频| 欧美黑人性生活视频| 精品一区二区三区电影| 青青在线视频一区二区三区| 日韩a**站在线观看| 亚洲欧美日韩一区二区三区在线| 亚洲欧美日韩直播| 国产一区二区三区四区福利| 成人精品视频99在线观看免费| 日韩av片免费在线观看| 成人免费自拍视频| 欧美成人自拍视频| 欧美在线欧美在线| 日本一区二区三区在线播放| 日本精品一区二区三区在线| 狠狠操狠狠色综合网| 91精品视频观看| www.亚洲人.com| 欧美在线视频免费观看| 精品久久中文字幕久久av| 国产精品视频yy9099| 欧美日韩国产麻豆| 亚洲国产小视频在线观看| 久久久电影免费观看完整版| 亚洲成年人在线| 国产精品一区二区电影| 欧美一级在线亚洲天堂| 亚洲美女在线视频| 国产精品专区h在线观看| 亚洲第一av网| 91精品视频观看| 久久香蕉国产线看观看网| 成人国产精品久久久| 精品亚洲国产成av人片传媒| 国产第一区电影| 一个人看的www欧美| 欧美肥婆姓交大片| 永久免费毛片在线播放不卡| 亚洲女同精品视频| 亚洲精品久久久一区二区三区| 茄子视频成人在线| 日韩欧美一区二区三区| 午夜精品在线观看| 欧美成人h版在线观看| 色哟哟网站入口亚洲精品| 一区二区三区久久精品| 亚洲午夜精品视频| 欧美日韩福利在线观看| 国产欧美在线看| 久久伊人色综合| 成人h猎奇视频网站| 亚洲网站在线播放| 日韩国产欧美精品在线| 一区二区三区 在线观看视| 亚洲情综合五月天| 亚洲天堂免费观看| 久久精品国产精品亚洲| 海角国产乱辈乱精品视频| 亚洲一级黄色片| 亚洲欧洲一区二区三区久久| 欧美性视频在线| 精品毛片三在线观看| 亚洲一区二区三区777| 亚洲国产成人久久综合| 57pao国产精品一区| 亚洲人成在线一二|