반응형
요즘 Ruby on Rails (ROR) 로 커피 온라인 샾을 구성중이다.
xp 방법론을 사용하여 일단 스토리 카드를 작성, googlecode 에 올려 팀과 함께 공유중이며, 일단 ROR 관련 공부를 하겠다는 취지하에 시작한 프로젝트라서 하나의 작업이 완료되면 서로 공유하는 시간을 가지고 있다.

일단 지금은 공통 코드 및 사용자 로그인 부분을 작업 중이며, 나는 공통 코드 중 국가 코드와 농장 코드를 맡게 되었다.
커피의 제품 표시 및 원산지 표시를 하기 위해 국가 및 농장 코드를 공통 코드로 나누었고, 국가 코드엔 국가 별로 커피 등급을 지정하는 표기법이 다르기에 5가지 단계로 나누어 입력하게 넣어 두었다.

농장코드는 농장 이름과 국가 코드를 가지고 있으며 최종적으로 상품 입력시 국가 이름과 농장 이름, 그리고 커피 등급으로 제품 이름이 결정되게 된다.

국가 코드를 만드는 부분은 별다르게 어려운 부분이 없었다. 바로 scaffold 하여 입력시 국가 이름을 한글 영문으로 넣는 부분을 확인하며 영문 부분은 중복 이름 확인 기능을 넣어 주었다.

문제는 농장 코드 입력 부분인데, 여기서 Dropdown 리스트를 만드는 부분에서 이해 하기는 쉬웠지만 사용하기까지 어려운 부분이 있어 잠시 적어보려고 한다.

국가 코드의 id 필드를 참조하여 농장 코드 입력 시 사용자 화면에서는 Dropdown List 로 국가명을 보여주고, 저장시엔 농장 테이블에 국가 코드 id 를 저장케 했다.



자 여기서 농장 테이블(farms) 와 나라 테이블 (nationals) 와의 관계를 적어줘야 하는데, farms 모델 파일인 farms.rb 에서 농장 테이블이 나라 테이블에 national_id 를 foreign_key 로 호함되어 있다고 알려주었고

또한 nationals.rb 에서 국가 테이블은 여러개의 농장 테이블을 가지고 있다고도 알려주어 서로의 관계를 만들어 주었다.

Rails 에는 Find 명령어가 있다. 기본적으로 controller 에서 아래의 명령어를 Controller 에 주면 @farm 객체에 id 순으로 "select * from farms" 의 내용을 담아둔다.


객체변수 선언을 위와 같이  controller 에서 해주면, farms 의 view 단에서 db 에서 들고 온 정보들을 원하는데로 사용할 수 있다. 기본적으로 New, Show, Edit, Delete 가 만들어지는 ROR 에서, 일단 New 에 Dropdown List 를 만들어 보았다.


collection_select 헬퍼(helper) 는 dropdown 리스트를 뷰단에 작성을 해준다. 이때 저장되어야 하는 모델 과 저장 될 모델의 필드명을 지정 해 주고, 보여줄 값들을 가지고 있는 객체변수명과 option 값, 그리고 dropdownlist 에 보여주는 값을 지정 해 준다.

<작성된 html, new.html.erb>

여기서 option 으로 blank 필드를 위에 올려줄 수 도 있고, blank값을 지정 해 줄 수도 있다.


<작성된 html new.html.erb>

자 여기까지는 new.html.erb 에서 농장 이름과, 농장의 나라 이름을 dropdown list 에서 선택하여 farms 테이블의 national_id 에 nationals 테이블의 id 값을 넣는 작업을 하였다.


반응형

+ Recent posts