Hibernate@Formula使用チュートリアル
使用方法
注意:()を使用してsqlフラグメントをラップする必要があります.hibernateはデータベースにuserSize対応のカラムを作成しません.
生成されたhibernateで生成されたsqlを表示すると、明らかにデータベースで演算されています.
このように遊ぶこともできます
プロキシの下でユーザーの合計数を問い合わせる
@Formula("(select count(*) from tbl_auth_user o where o.agent_id = id)")
idは現在のテーブルのidを表す
その他の使用例
@Formula(公式)はいいけど、悪用しないでね
private Long usersSize;
@Formula("(id * 8888888)")
@JsonProperty
public Long getUsersSize(){
return usersSize;
}
public void setUsersSize(Long usersSize) {
this.usersSize = usersSize;
}
。。。。
注意:()を使用してsqlフラグメントをラップする必要があります.hibernateはデータベースにuserSize対応のカラムを作成しません.
生成されたhibernateで生成されたsqlを表示すると、明らかにデータベースで演算されています.
select agent0_.id as id1_, agent0_.acl_code as acl2_1_, agent0_.acl_type as acl3_1_, agent0_.created_by
as created4_1_, agent0_.created_dt as created5_1_, agent0_.updated_by as updated6_1_, agent0_.updated_dt
as updated7_1_, agent0_.version as version1_, agent0_.agent_addres as agent9_1_, agent0_.agent_city
as agent10_1_, agent0_.agent_county as agent11_1_, agent0_.agent_name as agent12_1_, agent0_.agent_province
as agent13_1_, agent0_.agent_scale as agent14_1_, agent0_.zip_code as zip15_1_, agent0_.biz_lic_reg_no
as biz16_1_, agent0_.join_date as join17_1_, agent0_.oper_org_type as oper18_1_, agent0_.org_code_cert_no
as org19_1_, (agent0_.id * 8888888) as formula0_ from agent_agent agent0_ order by agent0_.created_dt
desc limit 15
このように遊ぶこともできます
プロキシの下でユーザーの合計数を問い合わせる
@Formula("(select count(*) from tbl_auth_user o where o.agent_id = id)")
idは現在のテーブルのidを表す
@Formula("(select count(*) from tbl_auth_user o where o.agent_id = id)")
@JsonProperty
public Long getUsersSize(){
return usersSize;
}
hibernate生成sqlselect agent0_.id as id1_, agent0_.acl_code as acl2_1_, agent0_.acl_type as acl3_1_, agent0_.created_by
as created4_1_, agent0_.created_dt as created5_1_, agent0_.updated_by as updated6_1_, agent0_.updated_dt
as updated7_1_, agent0_.version as version1_, agent0_.agent_addres as agent9_1_, agent0_.agent_city
as agent10_1_, agent0_.agent_county as agent11_1_, agent0_.agent_name as agent12_1_, agent0_.agent_province
as agent13_1_, agent0_.agent_scale as agent14_1_, agent0_.zip_code as zip15_1_, agent0_.biz_lic_reg_no
as biz16_1_, agent0_.join_date as join17_1_, agent0_.oper_org_type as oper18_1_, agent0_.org_code_cert_no
as org19_1_, (select count(*) from tbl_auth_user o where o.agent_id = agent0_.id) as formula0_
from agent_agent agent0_ order by agent0_.created_dt desc limit 15
その他の使用例
@Formula("(select min(o.creation_date) from Orders o where o.customer_id = id)")
private Date firstOrderDate;
@Formula("(select max(o.creation_date) from Orders o where o.customer_id = id)")
private Date lastOrderDate;
@Formula("(select coalesce(extract ('day' from age(max(o.creation_date))), 9999) from Orders o where o.customer_id = id)")
private int daysSinceLastOrder;
@Formula(公式)はいいけど、悪用しないでね