달력

12

« 2024/12 »

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
MVC 패턴을 이용하여, 기본적인 페이지를 만드는 것은 별로 어렵지 않다. 그리고 scaffold를 이용하여 기본적인 뼈대를 만들어서 원하는 기능을 살을 붙이듯이 개발해 나갈 수 있다.
Active Record는 데이터 레이어와 비스니스 레이어를 위해서 데이터를 관리하고 쉽게 사용할 수 있도록 도와준다.


6. Active Record
    : Active Record는 레일즈 애플리케이션과 데이터베이스 간의 연동을 담당한다.
    : 액티브 레코드에서는 레코드 객체를 통해서 데이터베이스 테이블을 조작한다.
    : 각각의 레코드는 데이터베이스 테이블에서 각각의 행과 대응하고, 각각의 액티브 레코드 객체는 데이터베이스 조작에 필요한
      CRUD(생성, 읽기, 수정, 삭제)메소드들을 가지고 있다.
 
    6.1 Active Record의 3가지 특징
        : 설정 대신 컨벤션 이용: 규약에 따라서 필요한 규칙들을 암묵적으로 정의하여 사용한다.
        : 멘타 프로그래밍: 데이터베이스 테이블에 정의된 컬럼들을 찾아서 대응되는 객체의 속성으로 추가하는 작업을 자동을 해준다.
        : 맵핑 언어: 맵핑 언어를 사용하여 테이블 간의 관계를 지정한다.
 
7. Database 설정
    : Active Record를 이용아혀 여러가지 Data base를 사용할 수 있지만, 나는 sqlite의 사용을 위한 database을 설정하려한다.
    : "config"디렉토리 아래의 database.yml 파일을 다음과 같이 설정한다.
    
    -Code in database.yml-

        development:
          adapter: sqlite
          database: db/photos_development

        test:
          adapter: sqlite
          database: db/photos_test
        production:
          adapter: sqlite
          database: db/photos_production

     7.1 Shema Migration

        : 아래와 같이 Model을 생성한다.

        => ruby script/generate model Photo

        : 위 코드를 통해서 app/modes/photo.rb 파일안에 모델 객첵가 생성된다.

        : Shema Migration을 통하면 데이터베이스와 독립적인 스키마를 구성할 수 있다.

     

    7.2 Shema Migration 설정

        : "config/enviroment.rb"파일을 열어 "config.active_record.schema_format = :ruby"로 설정해주면되나,

        : RubyOnRails 1.1 이후 버전은 이 값이 기본 설정 값이므로, 변경할 필요는 없다.

 

    7.3 up/down 메소드 설정

        :"db/migrate"디렉토리의 001_create_photos.rb 파일을 열고 다음과 같이 수정한다.

        

        -Code in 001_create_photos.rb-

        class CreatePhotos < ActiveRecord::Migration
          def self.up
            create_table :photos do |photo|
              photo.column "filename", :string
            end
          end

          def self.down
            drop_table :photos
          end
        end
 

 8. 기본 액티브 레코드 클래스

    : 마이그레이셔이나 SQL명령, 어느 것을 사용하더라도 작명 규약을 반드시 지켜야 한다.

    : 테이블 이름이나 id 컬럼의 정의등 모두 작명규약에 따라서 이름이 만들어진다.

 

    8.1 Rails의 작명 규약

        :클래스와 테이블 이름

            . 레일즈는 액티브 레코드 클래스 이름의 영문 복수형을 데이터베이스 테이블 이름으로 간주하여 테이블을 찾는다.

        :식별자

            . 액티브 레코드는 "id"란 이름의 컬럼을 찾아 유일한 식별자로 사용한다. "id"컬럼은 정수형이어야 하며, 데이터베이스는

              이 컬럼을 키로 사용해야 한다.

        :외래키

            . 외래키는 <clise>_id 의 형태로 이름이 지어져야 한다.

        : 대문자 표기

            . 클래스를 정의할 때 클래스 이름은 각 단어의 첫번째 글자는 대문자로 하고 단어 사이의 공백을 없앤다.

            . 메소드, 데이터베이스테이블 이름, 컬럼 이름. 속성 이름, 심벌 이름등은 단어 사이의 공백을 '_'문자로 대체한다.     

 9. Rails Console
    : 레일즈 콘솔은 데이터베이스와 모델 간의 유기적인 작업을 할 수 있도록 해준다.
    : 이는 다음과 같은 작업을 하도록 도와준다.
        . 데이터 베이스와 연결한다.
        . app/model에 있는 액티브 레코드 클래스들을 불러온다.
        . 데이터베이스와 모델 간에 데이터베이스 작업을 포함하여 유기적인 작업을 할 수 있게 해준다.
    : 다음과 같이 실행한다.
    => ruby script/console

디버깅과 개발에 활용할 수 있는 콘솔화면이 실행됨을 볼수 있을 것이다.
참고로, 나의 개발 환경이 윈도우 이므로 "ruby + command"의 형태롤 도스모드에서 명령을 실행하고 있다.
:
Posted by 행복상자