12/08/2018, 18:20

Tìm hiểu gem Seed Fu

Seed Fu là một gem cung cấp chức năng nâng cao tạo dữ liệu cho CSDL trong ứng dụng Rails của bạn. Seed Fu cung cấp một số tính năng làm cho nó trở thành một lựa chọn tốt hơn đáng kể so với chức năng mặc định trong Rails. Để bắt đầu, Seed Fu cho phép bạn tạo các bộ seed một cách nhanh chóng và dễ ...

Seed Fu là một gem cung cấp chức năng nâng cao tạo dữ liệu cho CSDL trong ứng dụng Rails của bạn. Seed Fu cung cấp một số tính năng làm cho nó trở thành một lựa chọn tốt hơn đáng kể so với chức năng mặc định trong Rails. Để bắt đầu, Seed Fu cho phép bạn tạo các bộ seed một cách nhanh chóng và dễ dàng dựa trên môi trường bạn đang thao tác. Ví dụ, Trên development bạn có thể có một bộ dữ liệu cho development và trên production cũng vậy. Ngoài ra, Seed Fu nhanh hơn nhiều vì nó bỏ qua callbacks.

Chú ý

Phiên bản 2.0.0 của Seed Fu đã giới thiệu các thay đổi API. Seed::Writer đã được sửa chữa hoàn toàn và sẽ yêu cầu bạn cập nhật tập lệnh của mình. Một số khác đã được giới thiệu và hỗ trợ, xóa hoàn toàn trong phiên bản 2.1.0. Vui lòng xem CHANGELOG để biết chi tiết.

Documentation đầy đủ tại đây.

Cài đặt

Rails 3.1, 3.2, 4.0, 4.1, 4.2, 5.0

Thêm gem 'seed-fu', '~> 2.3' đến Gemfile của bạn.

Rails 3.0

Phiên bản hiện tại không tương thích ngược với Rails 3.0. Vui lòng sử dụng gem 'seed-fu', '~> 2.0.0'.

Rails 2.3

Phiên bản hiện tại không tương thích ngược với Rails 3.0. Vui lòng sử dụng 'seed-fu', '~> 1.2.0'.

=> Sau đó chạy bundle install trên terminal

Ví dụ

Trong db/fixtures/users.rb thêm dữ liệu cho bảng/đối tượng user

User.seed do |s|
  s.id    = 1
  s.login = "jon"
  s.email = "jon@example.com"
  s.name  = "Jon"
end

User.seed do |s|
  s.id    = 2
  s.login = "emily"
  s.email = "emily@example.com"
  s.name  = "Emily"
end

Để chạy và load dữ liệu đến database.

$ rake db:seed_fu
== Seed from /path/to/app/db/fixtures/users.rb
 - User {:id=>1, :login=>"jon", :email=>"jon@example.com", :name=>"Jon"}
 - User {:id=>2, :login=>"emily", :email=>"emily@example.com", :name=>"Emily"}

Tính ràng buộc (Constraints)

Càng ràng buộc được xác định trong seeds, để chúng có thể update! nếu cần thiết.

Point.seed(:x, :y) do |s|
  s.x = 4
  s.y = 7
  s.name = "Home"
end

Lần đầu tiên seed file được load, một đối tượng Point sẽ được tạo ra. Bây giờ muốn thay đổi name và giữ nguyên x,y

Point.seed(:x, :y) do |s|
  s.x = 4
  s.y = 7
  s.name = "Work"
end

Khi chạy seed fu sẽ tìm kiếm 1 đối tượng point với giá trị của x và y. Nếu đối tượng được tìm thấy nó sẽ update! giá trị của name chứ không tạo một bản ghi mới.

Nếu bạn muốn tạo một bản ghi mới thay vì update giá trị hãy sử dụng seed_once:

Point.seed_once(:x, :y) do |s|
  s.x = 4
  s.y = 7
  s.name = "Home"
end

Ràng buộc mặc định sẽ kiểm tra theo id của bản ghi.

Nơi để thiết lập các thông tin seed files

Mặc định seed files sẽ được tìm đến địa chỉ như bên dưới:

  • #{Rails.root}/db/fixtures và #{Rails.root}/db/fixtures/#{Rails.env}
  • ./db/fixtures Bạn có thể thay đổi các giá trị này bằng cách sửa trong mảng SeedFu.fixture_paths, và bạn có thể đặt tên các seed files tùy ý.

Cú pháp Terser

Khi load số lượng bản ghi lớn, cú pháp dựa trên block khá là dài dòng, bạn có thể sử dụng như bên dưới:

User.seed(:id,
  { :id => 1, :login => "jon",   :email => "jon@example.com",   :name => "Jon"   },
  { :id => 2, :login => "emily", :email => "emily@example.com", :name => "Emily" }
)
0