У меня на завтра запланированы ассоциации, я пока не дошёл до них
No-Tactic, ага их.
просто смотри, я вижу, что ты в моделе перечислил аттрибуты name, email, text без указания типа, но в файле миграции они имеют тип string, а также еще добавилось 2 поля даты. Откуда при миграции мы узнаем, что name это string? или если мы явно не указали тип данных, то оно по дефолту делает string?
изза этой магии мне и не понравился RoR
flaky (25.07.2013 / 20:02)
просто смотри, я вижу, что ты в моделе перечислил аттрибуты name, email, text без указания типа, но в файле миграции они имеют тип string, а также еще добавилось 2 поля даты. Откуда при миграции мы уз
Ну дак мы же сами написали в миграции, что name это string
Мы пишем в миграции нужные нам поля с указанием их типа, потом выполняем не и создаётся таблица в бд.
А модель нужна только для доступа к данным в этой таблице
No-Tactic, ясн. просто я привык в джанге/алхимии что сразу в моделе описываеться тип данных, поэтому мне это в диковену. да и как то не удобно
Плюшки из Rails
1) создание приложения: пишем в консоли
rails new appname
и нам генерирует основную структуру файлов.
2) создание контроллера: в консоли
rails g controller contoroller_name
создается сам контроллер, хелпер для стандартных CRUD адресов, и юнит тесты(читаем о TDD, если не знаем, что это) контроллер генерируется пустой
3) создание модели: в консоли
rails g model model_name
создается модель, миграция и тесты. Модель и миграция пустые
4) есть такая фишка с названием скаффолдинг (правда я ни разу не пользовался, так что сам сказать не могу читаем
http://rubyclub.blogspot.ru/20 ... .html )
в общем, эта фича сама генерирует бульшую часть кода приложения
5) по умолчанию есть чпу роуты. Для стандартного CRUD приложения достаточно строки
resources :posts
чтобы создать адреса:
/posts - экшен: posts#index. все посты, тип запроса GET
/posts/id - экшен: posts#show. отдельный пост, тип запроса GET
/posts/id/edit - экшен: posts#edit. изменение поста, тип запроса GET
/posts/new - экшен: posts#new. создание поста, тип запроса GET
/posts - экшен: posts#create. сюда отправляется запрос из экшена new, тип запроса POST
/posts/id - экшен: posts#update. сюда отправляется запрос из экшена edit, тип запроса PUT
/posts/id - экшен: posts#destroy. Удаление поста. тип запроса DELETE
6) можно использовать PostgreSQL, MySQL, SQLlite изменяя только гем для используемой бд (одна строчка)
flaky, тип связи has one/belongs to (one-to-one)
допустим, у нас есть магазин.
В бд две таблицы Users, Carts. логично предположить, что у одного юзера одна корзина
В миграции для Users никаких дополнительных полей не нужно
В миграции для Carts добавляем поле типа Integer с названием user_id
в модели user, в контексте класса пишем
has_one :cart
в модели cart, так же в контексте класса
belongs_to :user
все, и теперь у нас есть свойство cart для юзера, которому можно присвоить обьект класса корзина
продолжаем с магазином
связь has many/belongs to (many-to-one)
у нас есть пользователи. Каждый пользователь может создать много заказов
в миграции для Users оставляем все так же, в миграцию orders пишем поле user_id
в модели user пишем
has_many :orders # именно orders т.к заказов много
и в модели order
belongs_to :user
теперь можно присвоить много заказов пользователю
Вопрос к администрации: можно ли будет тут ссылку разместить на свеженький проект на рельсах?
пока пилил бложек (без уроков всяких и прочей ереси) было все легко и непринужденно, залил на сервак и начались неожиданности:
оказывается, в production окружении, все js и css файлы минимизируются и кэшируются в папочку public, и умные рельсы берут их оттуда. я долго парился с настррйкой, чтоб это все было автоматом при изменении в файлах. не получилось, минимизируем командой в консольке.
в продакшен окружении после каждого изменения в коде приходится перезапускать nginx и passenger