Model

๋ชจ๋ธ ํด๋ž˜์Šค ์ƒ์„ฑ

rails generate model name field:type

์ข…๋ฅ˜

์„ค๋ช…

์˜ˆ

๋ชจ๋ธ ํด๋ž˜์Šค

์ฒซ ๊ธ€์ž ๋Œ€๋ฌธ์ž,๋‹จ์ˆ˜ํ˜•

Book

๋ชจ๋ธ ํด๋ž˜์Šค ํŒŒ์ผ ์ด๋ฆ„

์ฒซ๊ธ€์ž ์†Œ๋ฌธ์ž, ๋‹จ์ˆ˜ํ˜•

book.rb

ํ…Œ์ด๋ธ”

์ฒซ๊ธ€์ž ์†Œ๋ฌธ์ž, ๋ณต์ˆ˜ํ˜•

books

ํ…Œ์ŠคํŠธ ์Šคํฌ๋ฆฝํŠธ

xxxx_test.rb(์ฒซ๊ธ€์ž ์†Œ๋ฌธ์ž,๋‹จ์ˆ˜ํ˜•)

book_test.rb

๋งˆ์ด๊ทธ๋ ˆ์ด์…˜ ํŒŒ์ผ๋กœ ํ…Œ์ด๋ธ” ์ƒ์„ฑ

๋งˆ์ด๊ทธ๋ ˆ์ด์…˜ : ํ…Œ์ด๋ธ” ๋ ˆ์ด์•„์›ƒ์„ ์ƒ์„ฑ ๋˜๋Š” ๋ณ€๊ฒฝํ•˜๊ธฐ ์œ„ํ•œ ๊ตฌ์กฐ.

rails dbconsoleor rails db์„ ์‚ฌ์šฉํ•˜๋ฉด config/database.yml์— ์ •์˜๋œ ์ •๋ณด๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ํด๋ผ์ด์–ธํŠธ๋ฅผ ์‹คํ–‰ํ•  ์ˆ˜ ์žˆ๋‹ค.

.tables : ํ…Œ์ด๋ธ” ๋ชฉ๋กํ‘œ์‹œ .schema books : booksํ…Œ์ด๋ธ”์˜ ๊ตฌ์กฐํ™•์ธ select*from books; : booksํ…Œ์ด๋ธ”๋‚ด์šฉํ™•์ธ

์ด๋•Œ ์ด์˜๊ฒŒ ๋ณด๊ณ ์‹ถ๋‹ค๋ฉด .headers on .mode columns๋ฅผ ํ•ด์ฃผ๋ฉด ๋œ๋‹ค.

.exit or .quit : ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ํด๋ผ์ด์–ธํŠธ ์ข…๋ฃŒ

๋ฐ์ดํ„ฐ ์ถ”์ถœ

1. Primary Key๋กœ ๊ฒ€์ƒ‰์„ ํ•œ๋‹ค. (find)

find(keys) keys:์ฃผ ํ‚ค(๋ฐฐ์—ด๋กœ ์ง€์ •ํ•  ์ˆ˜๋„ ์žˆ๋‹ค.)

2. ์ž„์˜์˜ ํ•„๋“œ๋กœ ๊ฒ€์ƒ‰(find_by)

:๊ฒ€์ƒ‰ ์กฐ๊ฑด์œผ๋กœ ๊ฐ€์žฅ ์ฒ˜์Œ ๊ฒ€์ƒ‰๋˜๋Š” ๋ ˆ์ฝ”๋“œ๋ฅผ ์ถ”์ถœํ•œ๋‹ค. find_by key: value [, ... ]

find_by๊ฐ€ ๋ฆฌํ„ดํ•˜๋Š” ๋ฐ์ดํ„ฐ๋Š” ํ•ญ์ƒ ํ•˜๋‚˜์ด๋‹ค. ๊ทธ๋Ÿฌ๋ฏ€๋กœ ํ…Œ์ด๋ธ” ์กฐ๊ฑด์— ๋งž๋Š” ๋ ˆ์ฝ”๋“œ๊ฐ€ ํ•˜๋‚˜๋งŒ ์žˆ์„๋•Œ๋งŒ ์‚ฌ์šฉํ•œ๋‹ค.

3. ์ง€์ •ํ•œ ํ•„๋“œ ๋ฐ์ดํ„ฐ๋ฅผ ๋ฐฐ์—ด ์ถ”์ถœ(pluck(column, ... ))

: ์—ฌ๋Ÿฌ๊ฐœ์˜ ํ•„๋“œ๋ฅผ ์ง€์ •ํ•ด์„œ ์ถ”์ถœํ•˜๋Š” ๊ฒƒ์ด ๊ฐ€๋Šฅํ•ด์กŒ๋‹ค.

ex) Book.where(publish: '์ œ์ดํŽ').pluck(:title, :price)

4. ๋ฐ์ดํ„ฐ ์กด์žฌํ™•์ธ(exists?)

: ๋ฐ์ดํ„ฐ๋ฅผ ์ถ”์ถœํ•˜์ง€ ์•Š๊ณ  ์ง€์ •๋œ ๋ฐ์ดํ„ฐ๊ฐ€ ์žˆ๋Š”์ง€ ์—†๋Š”์ง€ ์ •๋„๋งŒ ํ™•์ธํ•˜๊ณ  ์‹ถ์„๋•Œ.

5. Named Scope(์ด๋ฆ„์žˆ๋Š” ์Šค์ฝ”ํ”„)

scope name , -> {exp} : ํŠน์ •ํ•œ ์กฐ๊ฑด์‹ ๋˜๋Š” ์ •๋ ฌ์‹์„ ๋ฏธ๋ฆฌ ๋ชจ๋ธ์ชฝ์— ์ด๋ฆ„์„ ๋ถ™์—ฌ ์ €์žฅํ•ด๋‘๊ณ , ํ›„์— ์ด์šฉํ•˜๊ณ  ์‹ถ์„๋•Œ ์ด๋ฆ„์„ ํ˜ธ์ถœํ•ด์„œ ์‚ฌ์šฉํ•œ๋‹ค.

ex)

 scope :top10, -> {newer.limit(10)}

6. ๊ธฐ๋ณธ์Šค์ฝ”ํ”„ ์ •์˜(default_scope exp)

: ๋ชจ๋ธ ๊ด€๋ จ ๋ฉ”์„œ๋“œ๋ฅผ ํ˜ธ์ถœํ•  ๋•Œ ์ž๋™์œผ๋กœ ์กฐ๊ฑด์ด ์ ์šฉ๋˜๊ฒŒํ•˜๋Š” ๊ธฐ๋ณธ์Šค์ฝ”ํ”„

ex)

default_scope{order(updated_at: :desc)}

7. ์กฐ๊ฑด์— ๋งž๋Š” ๋ ˆ์ฝ”๋“œ ์ˆ˜ ์ถ”์ถœ(count)

: ํŠน์ • ์กฐ๊ฑด์— ๋งž๋Š” ๊ฒฐ๊ณผ ์ง‘ํ•ฉ ๊ฐœ์ˆ˜๋ฅผ ์ถ”์ถœํ•  ๋•Œ ์‚ฌ์šฉ.

ex)

Book.where(school: 'konkuk').count

ํ‰๊ท (average(col)) / ์ตœ์†Œ(minimum(col)) / ์ตœ๋Œ€(maximum(col)) / ํ•ฉ (sum(col))

๊ฒ€์ƒ‰์ฒ˜๋ฆฌ - ์ฟผ๋ฆฌ ๋ฉ”์„œ๋“œ

:find, find_by ๋ฉ”์„œ๋“œ์™€ ๋‹ค๋ฅด๊ฒŒ ํ˜ธ์ถœํ•˜๋Š” ์‹œ์ ์—๋Š” ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์— ์ ‘๊ทผํ•˜์ง€ ์•Š๋Š”๋‹ค. ์ดํ›„์— ์ฟผ๋ฆฌ ๊ฒฐ๊ณผ๊ฐ€ ํ•„์š”ํ•œ ์‹œ์ ์— ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์— ์ ‘๊ทผํ•œ๋‹ค. (์ง€์—ฐ๋กœ๋“œ(Lazy Load))

1.where

  • where(exp) : ๊ธฐ๋ณธ์ ์ธ ์กฐ๊ฑด์‹ (exp๋Š” ์กฐ๊ฑด์‹์„ ๋‚˜ํƒ€๋‚ด๋Š” ํ•ด์‹œ)

    ex) @books = Book.where(name: 'dahye') where์—์„œ AND๋Š” ,, BETWEEN ์€ .., IN์€ name: [dahye, miyoen]์„ ํ†ตํ•ด์„œ ์—ฌ๋Ÿฌ๊ฐ€์ง€ ์กฐ๊ฑด์„ ํ•œ๋ฒˆ์— ๊ฒ€์ƒ‰ํ•  ์ˆ˜ ์žˆ๋‹ค.

  • where((exp [value, ... ]) : placeholder(๋งค๊ฐœ ๋ณ€์ˆ˜๋ฅผ ๋‘๋Š” ์žฅ์†Œ)๋ฅผ ์ด์šฉํ•œ ์กฐ๊ฑด์‹.

2.not : ๋ถ€์ •์กฐ๊ฑด์‹

ex) Book.where.not(isbn: parmas[:id])

3.order(sort) : ๋ฐ์ดํ„ฐ์ •๋ ฌ

4.redorder : ๋ฐ์ดํ„ฐ ์žฌ์ •๋ ฌ

5.select(cols) : ์ถ”์ถœํ•  ํ•„๋“œ ๋ช…์‹œ์  ์ง€์ •

6.distinct([flag]) : ์ค‘๋ณต๋˜์ง€ ์•Š๋Š” ๋ ˆ์ฝ”๋“œ ์ถ”์ถœ(์ค‘๋ณต์ œ๊ฑฐ)

7.limit(rows) / offset(off) : ์ง€์ •๋ฒ”์œ„ ๋ ˆ์ฝ”๋“œ ์ถ”์ถœ

8.first/ last : ์ฒซ ๋ ˆ์ฝ”๋“œ / ๋งˆ์ง€๋ง‰ ๋ ˆ์ฝ”๋“œ ์ถ”์ถœ

9.group(key) : ๋ฐ์ดํ„ฐ ๊ทธ๋ฃนํ™”(ํŠน์ •ํ•œ ํ‚ค๋กœ ๋ฐ์ดํ„ฐ๋ฅผ ๊ทธ๋ฃนํ™”ํ•˜๊ณ  ์‹ถ์€ ๊ฒฝ์šฐ

10.having(exp, [,value, ... ]) : ๊ทธ๋ฃนํ™”ํ•œ ๊ฒฐ๊ณผ์— ์ถ”๊ฐ€ ์กฐ๊ฑด

11.! : ๋์— !๋ฅผ ๋ถ™์—ฌ ์กฐ๊ฑด์‹์„ ์—ฌ๋Ÿฌ๊ฐœ์˜ ์ค„์—๊ฑธ์ณ ๋‹จ๊ณ„์ ์œผ๋กœ ์ ์šฉํ•˜๋Š”๊ฒŒ ๊ฐ€๋Šฅํ•ด์ง.

12.unscope(skips) : ์ฟผ๋ฆฌ๋กœ ๋งŒ๋“  ์กฐ๊ฑด์ œ๊ฑฐ

13.none : ์•„๋ฌด๊ฒƒ๋„ ์—†๋Š” ๊ฒฐ๊ณผ

๋ ˆ์ฝ”๋“œ ์ถ”๊ฐ€ / ์ˆ˜์ • / ์ œ๊ฑฐ

์—ฌ๋Ÿฌ๊ฐœ ๋ ˆ์ฝ”๋“œ ํ•œ๋ฒˆ์— ์ˆ˜์ •(update_all(updates))

ex)

Book.where(publish: 'ํ•œ๋น›๋ฏธ๋””์–ด').update_all(publish: 'jpub')

๋ ˆ์ฝ”๋“œ ์ œ๊ฑฐ(destroy / delete / destroy_all(cond))

: destroy๋Š” SELECT -> DELETE ์ˆœ์„œ, delete๋Š” DELETE๋งŒ ํ˜ธ์ถœํ•œ๋‹ค. ์ด๋Ÿฌํ•œ ์ฐจ์ด๋กœ association or callback ๊ธฐ๋Šฅ์— ์ฐจ์ด๊ฐ€ ๋‚œ๋‹ค. ๊ฐ„๋‹จํ•˜๊ฒŒ ๋ฐ์ดํ„ฐ ์ œ๊ฑฐ๋งŒ ํ•  ๋•Œ๋Š” delete๋ฅผ ์‚ฌ์šฉํ•˜๋Š”๊ฒŒ ์ข‹๋‹ค.

: destroy_all์€ ํŠน์ •์กฐ๊ฑด์— ๋งž๋Š” ๋ ˆ์ฝ”๋“œ๋ฅผ ํ•œ๊บผ๋ฒˆ์— ์ œ๊ฑฐํ• ๋•Œ ์‚ฌ์šฉ.

ํŠธ๋žœ์žญ์…˜ ์ฒ˜๋ฆฌ(transaction)

: ๋ชจ๋“  ๋ช…๋ น์–ด์˜ ์„ฑ๊ณต, ์‹คํŒจ๋ฅผ ํ•œ๊บผ๋ฒˆ์— ๋ชจ์•„์„œ ์ฒ˜๋ฆฌํ•˜๋Š” ๊ฒƒ์ด๋‹ค. ๋งŒ์•ฝ ํ•œ๊ฐœ๋ผ๋„ ์‹คํŒจํ•œ๋‹ค๋ฉด ํŠธ๋žœ์žญ์…˜ ์ฒ˜๋ฆฌ๋„ ์‹คํŒจํ•˜๊ณ  ์ด๋•Œ๊นŒ์ง€ ์‹คํ–‰๋๋˜ ๋ชจ๋“  ๋ช…๋ น์•„๊ฐ€ ๋ฌดํšจํ™”๋œ๋‹ค.

  • commmit : ํŠธ๋žœ์žญ์…˜ ์ฒ˜๋ฆฌ๋ฅผ ํ™•์ •ํ•˜๋Š” ๊ฒƒ

  • Rollback : ์ฒ˜๋ฆฌ๋ฅผ ์‹คํŒจํ•ด ํŠธ๋žœ์žญ์…˜ ์ƒํƒœ๋ฅผ ๋˜๋Œ๋ฆฌ๋Š”๊ฒƒ.

  • ํŠธ๋žœ์žญ์…˜ ๋ถ„๋ฆฌ ๋ ˆ๋ฒจ : ์—ฌ๋Ÿฌ๊ฐœ์˜ ํŠธ๋žœ์žญ์…˜์„ ๋™์‹œ ์‹คํ–‰ํ•œ ๊ฒฝ์šฐ์— ๋™์ž‘์„ ํ‘œ์‹œ. ๋ถ„๋ฆฌ ๋ ˆ๋ฒจ์ด ๋†’์œผ๋ฉด ๊ทธ๋งŒํผ ๋ฐ์ดํ„ฐ์˜ ์ •ํ•ฉ์„ฑ์€ ๋†’์•„์ง€์ง€๋งŒ ์‹คํ–‰์„ฑ์€ ๋‚ฎ์•„์ง„๋‹ค.

์ถฉ๋Œ : ๋™์‹œ์— ์ˆ˜์ •ํ•˜๋Š” ๊ฒฝ์šฐ์— ๋ฐœ์ƒ

  1. ํ…Œ์ด๋ธ”์— lock_version์ถ”๊ฐ€

  2. ๋™์‹œ์‹คํ–‰์ œ์–ด์ค€๋น„

  3. ์‹คํ–‰์ œ์–ด ์ž‘๋™ํ™•์ธ

  4. ์˜ˆ์™ธ๊ฒ€์ถœ๋œ ๊ฒฝ์šฐ์˜ ์ฒ˜๋ฆฌ

์šฉ์–ด์ •๋ฆฌ

rake db:seed : ์‹œ๋“œํŒŒ์ผ์„ ์ด์šฉํ•ด์„œ ๋ฐ์ดํ„ฐ๋ฅผ ์ดˆ๊ธฐํ™”ํ•˜๋Š” ๋ช…๋ น์–ด์ด๋‹ค. rake db:drop : ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ํŒŒ์ผ ์‚ญ์ œ

Last updated