BlazeDS 결합 Hibernate-PO 를 사용 할 지 VO 를 사용 할 지 에 대한 생각
3301 단어 jsonHibernateextFlexactionscript
PO 로 돌아 가 는 코드 량 은 VO 로 돌아 가 는 코드 량 보다 훨씬 적 고 번 거 로 운 중복 코드 를 피 할 수 있 습 니 다.그러나 저 는 PO 를 반환 값 으로 Flex 와 결합 하 는 과정 에서 문제 가 생 겼 습 니 다.특히 3~4 장의 표 깊이 와 관련 이 있 을 때 더욱 불편 합 니 다(예 를 들 어 학교-학원-반-학생,지금 어떤 학교의 학생 을 열거 해 야 합 니 다).다음은 간단 한 시계 두 장 을 예 로 들 자.
현재 두 장의 표 가 있다 고 가정 하면 TUser 와 TROL 은 각각 인원 표 와 캐릭터 표 로 1 대 1 관 계 를 가진다.
public class TUser implements java.io.Serializable {
private Integer userId;
private TRole TRole;
private String userName;
private String userPass;
private String userTname;
}
public class TRole implements java.io.Serializable {
private Integer roleId;
private String roleName;
private Set TUsers = new HashSet(0);
}
획득 인원
from TUser as ta join fetch ta.TRole
결 과 를 List
public class TUser
{
public var userId:int;
public var userName:String;
public var userPass:String;
public var userTname:String;
public var TRole:Object;
public function TUser (){
}
}
public class Roles
{
public var roleId:int;
public var roleName:String;
public var TUsers:Array;
public function Roles()
{
}
}
다음은 사용자 이름과 실제 이름 을 DataGrid 에 표시 합 니 다.주요 코드 는 다음 과 같 습 니 다.(중간 처리 반환 값 은 일정한 변환 을 해 야 합 니 다.코드 는 붙 이지 않 습 니 다)
<mx:DataGrid id="admDataGrid" dataProvider="{acPageData}"
editable="true">
<mx:columns>
<mx:DataGridColumn headerText=" " dataField=" userName "/>
<mx:DataGridColumn headerText=" " dataField=" userTname "/>
</mx:columns>
</mx:DataGrid>
그림 참조:
관리자 이름 을 표시 하려 면 사용 하 십시오.
<mx:DataGridColumn headerText=" " dataField=" TRole. roleName "/>
통 하지 않 는 다.
해결 방법 은 DataGridColumn 의 label Function 을 사용 하여 TROL 의 Object 를 진정한 Role 유형 으로 바 꾸 고 그의 role Name 으로 돌아 가 는 것 입 니 다.
코드:
다음 그림:
이렇게 보 이 는 문 제 는 해 결 된 것 같 지만 이 열 은 편집 할 수 없습니다.editable 을 true 로 설정 하고 관리자 열 을 편집 하면 오류 가 발생 할 수 있 습 니 다.
강제 변환 형식 실패:"관리자"를 vo.Roles 로 변환 할 수 없습니다.
그 이 유 는 editor 이후 에 label Function 의 대응 방법 을 호출 할 것 입 니 다.그리고 이 방법 은 시작 할 때 값 이 String 이 아니 라 Object 입 니 다.전환 할 수 있 지만 지금 은 안 됩 니 다.이 문 제 는 줄곧 해결 되 지 않 았 다.아마도 우 리 는 사용자 정의 구성 요 소 를 만 들 수 있 을 것 입 니 다.그 안에 roleId 와 roleName 이 있 습 니 다.roleName 을 표시 합 니 다.편집 할 때 roleId 에 따라 TROL 을 찾 아서 roleName 을 바 꾸 고.................................
만약 에 위의 우리 가 VO 를 사용한다 면 아무런 문제 가 없습니다.우 리 는 정상적으로 표시 하고 편집 할 수 있 습 니 다.심지어 우 리 는 VO 에 번 호 를 넣 어서 DataGrid 의 번 호 를 표시 할 수 있 습 니 다.이 기능 은 코드 한 마디 면 된다.
물론 VO 백 스테이지 코드 를 사용 하면 불필요 한 번 거 로 운 코드 가 많아 질 것 입 니 다.그러나 PO 문 제 는 해결 되 지 않 습 니 다.그러면 어떻게 선택 하 시 겠 습 니까?
(물론 이 문제 들 도 해결 방법 이 있 을 수 있 습 니 다.다만 저 는 발견 하지 못 했 습 니 다.알 고 싶 은 것 은 말씀 드 리 겠 습 니 다.하하)
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
콘텐츠 SaaS | JSON 스키마 양식 빌더Bloomreach Content를 위한 JSON Form Builder 맞춤형 통합을 개발합니다. 최근 Bloomreach Content SaaS는 내장 앱 프레임워크를 사용하여 혁신적인 콘텐츠 유형 필드를 구축할...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.