剛開源了一個經過完整測試的Java工具類。
地址如下:
https://github.com/Jimmy-Shi/bean-query
使用說明如下:
Bean-query
Click Here for English version.
BeanQuery 是一個把對象轉換為Map的Java工具庫。支持選擇Bean中的一些屬性,對結果進行排序和按照條件查詢。不僅僅可以作用于頂層對象,也可以作用于子對象。
BeanQuery的使用非常簡單也很直接,例子代碼如下:
1 //靜態導入BeanQuery
2 import static cn.jimmyshi.beanquery.BeanQuery.*;
3
4
5 //使用 select、from、where、orderBy、desc和asc來組裝一個Query,然后執行execute方法來獲得結果。
6 List<Map<String, Object>> result = select("price,name,mainAuthor.name as mainAuthorName")
7 .from(bookCollection)
8 .where(
9 //for books name is Book2 or starts with Book1
10 anyOf(
11 value("name", startsWith("Book1")),
12 value("name", is("Book2"))
13 ),
14 //for books price between (53,65)
15 allOf(
16 value("price", greaterThan(53d)),
17 value("price",lessThan(65d))
18 )
19 )
20 .orderBy("name").desc()
21 .execute();
在上面的例子中,bookCollection的內容如下所示(json格式)
[
{
"price":55.55,
"name":"Book1",
"mainAuthor":{
"name":"Book1-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518000"
},
"birthDate":"1982-01-30T14:52:39"
}
},
{
"price":52.55,
"name":"Book12",
"mainAuthor":{
"name":"Book1-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518000"
},
"birthDate":"1982-01-30T14:52:39"
}
},
{
"price":53.55,
"name":"Book13",
"mainAuthor":{
"name":"Book13-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518000"
},
"birthDate":"1982-01-30T14:52:39"
}
},
{
"price":60.0,
"name":"Book14",
"mainAuthor":{
"name":"Book14-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518000"
},
"birthDate":"1982-01-30T14:52:39"
}
},
{
"price":50.55,
"name":"Book15",
"mainAuthor":{
"name":"Book1-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518000"
},
"birthDate":"1982-01-30T14:52:39"
}
},
{
"price":77.77,
"name":"Book3",
"mainAuthor":{
"name":"Book3-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518005"
},
"birthDate":"1982-01-30T14:52:39"
}
}
,
{
"price":66.66,
"name":"Book2",
"mainAuthor":{
"name":"Book2-MainAuthor",
"address":{
"address":"Shenzhen Guangdong China",
"postCode":"518005"
},
"birthDate":"1982-01-30T14:52:39"
}
}
]
執行完之后,則result的內容如下所示(json格式)
[
{
"price":60.0,
"name":"Book14",
"mainAuthorName":"Book14-MainAuthor"
},
{
"price":53.55,
"name":"Book13",
"mainAuthorName":"Book13-MainAuthor"
},
{
"price":55.55,
"name":"Book1",
"mainAuthorName":"Book1-MainAuthor"
}
]