Phần tiếp theo là nhiều hơn một ORM. Đó là một giải pháp hoàn chỉnh để tương tác với cơ sở dữ liệu từ Ruby, quản lý và giao tiếp với toàn bộ cơ sở dữ liệu, không chỉ dữ liệu của nó.
Các nhà phát triển có thể sử dụng giao diện điều khiển IRB hoặc DSL riêng Sequel để nhanh chóng lắp ráp cơ sở dữ liệu, quản lý lược đồ, xây dựng các truy vấn SQL, các giao dịch chạy, lấy kết quả, và chuyển đổi các kết quả ra định dạng dẻo Ruby.
Nó hoạt động giống như một lớp trừu tượng giữa Ruby và SQL, giúp phát triển các kỹ năng Ruby, nhưng với kiến thức SQL thấp hơn.
cơ sở dữ liệu và các công cụ hỗ trợ:
ADO
Amalgalite
CUBRID
DataObjects
DB2
DBI
Firebird
IBM_DB
Informix
JDBC
MySQL
Mysql2
ODBC
OpenBase
Oracle
PostgreSQL
SQLAnywhere
SQLite3
Swift
TinyTDS
Điều gì là mới trong phiên bản này:
- Hãy dataset.call_sproc (: chèn) làm việc trong các bộ chuyển đổi jdbc
- Thêm Plugin update_refresh, để làm mới một trường hợp mô hình khi cập nhật
- Thêm Plugin delay_add_association, để trì hoãn add_ * phương pháp kêu gọi các đối tượng mới cho đến khi sau khi tiết kiệm các đối tượng
- Thêm Plugin validate_associated, để xác nhận đối tượng liên quan khi xác nhận đối tượng hiện tại
- Hãy Postgres :: JSONBOp # [] và #get_text trở lại trường JSONBOp
- Tháo fdbsql, jdbc / fdbsql, và bộ điều hợp openbase
- Cơ sở dữ liệu giao dịch # bây giờ trở về giá trị trả về khối nếu: rollback = & # x3e;: luôn luôn được sử dụng
- Cho phép postgresql: chuỗi // kết nối như là bí danh để Postgres: //, để tương thích với libpq
- Hãy Model # move_to trong các plugin danh sách xử lý out-of-range mục tiêu mà không cần nâng một ngoại lệ
- Tạo cơ sở dữ liệu # add_named_conversion_proc trên PostgreSQL procs xử lý chuyển đổi với nhiều loại enum
Điều gì là mới trong phiên bản 4.24.0:
- Hãy dataset.call_sproc (: chèn) làm việc trong adapter jdbc
- Thêm Plugin update_refresh, để làm mới một trường hợp mô hình khi cập nhật
- Thêm Plugin delay_add_association, để trì hoãn add_ * phương pháp kêu gọi các đối tượng mới cho đến khi sau khi tiết kiệm các đối tượng
- Thêm Plugin validate_associated, để xác nhận đối tượng liên quan khi xác nhận đối tượng hiện tại
- Hãy Postgres :: JSONBOp # [] và #get_text trở lại trường JSONBOp
- Tháo fdbsql, jdbc / fdbsql, và bộ điều hợp openbase
- Cơ sở dữ liệu giao dịch # bây giờ trở về giá trị trả về khối nếu: rollback = & # x3e;: luôn luôn được sử dụng
- Cho phép postgresql: chuỗi // kết nối như là bí danh để Postgres: //, để tương thích với libpq
- Hãy Model # move_to trong các plugin danh sách xử lý out-of-range mục tiêu mà không cần nâng một ngoại lệ
- Tạo cơ sở dữ liệu # add_named_conversion_proc trên PostgreSQL procs xử lý chuyển đổi với nhiều loại enum
Điều gì là mới trong phiên bản 4.22.0:
- Hãy jdbc / sqlanywhere thiết lập một cách chính xác: lối auto_increment trong băm giản đồ
- Thêm Model # cancel_action hủy hành động trước khi móc, thay vì có các móc trả lại giả
- Hỗ trợ không thiết @@ wait_timeout trên MySQL qua: timeout = & # x3e; lựa chọn cơ sở dữ liệu con số không
- Added accessed_columns plugin, ghi âm mà cột đã được đọc cho một trường hợp mô hình
- Sử dụng phiên bản di cư chính xác khi sử dụng IntegerMigrator với: allow_missing_migration_files
- Hãy Dataset # đoàn, #intersect, và #except tự động xử lý các tập dữ liệu với SQL nguyên
- Thêm column_conflicts plugin để tự động xử lý các cột xung đột với tên phương pháp
- Added Model # get_column_value và #set_column_value để nhận / đặt giá trị cột
Điều gì là mới trong phiên bản 4.21.0:
- Hãy jdbc / sqlanywhere thiết lập một cách chính xác: lối auto_increment trong băm giản đồ
- Thêm Model # cancel_action hủy hành động trước khi móc, thay vì có các móc trả lại giả
- Hỗ trợ không thiết @@ wait_timeout trên MySQL qua: timeout = & # x3e; lựa chọn cơ sở dữ liệu con số không
- Added accessed_columns plugin, ghi âm mà cột đã được đọc cho một trường hợp mô hình
- Sử dụng phiên bản di cư chính xác khi sử dụng IntegerMigrator với: allow_missing_migration_files
- Hãy Dataset # đoàn, #intersect, và #except tự động xử lý các tập dữ liệu với SQL nguyên
- Thêm column_conflicts plugin để tự động xử lý các cột xung đột với tên phương pháp
- Added Model # get_column_value và #set_column_value để nhận / đặt giá trị cột
Điều gì là mới trong phiên bản 4.19.0:
- Hãy jdbc / sqlanywhere thiết lập một cách chính xác: lối auto_increment trong băm giản đồ
- Thêm Model # cancel_action hủy hành động trước khi móc, thay vì có các móc trả lại giả
- Hỗ trợ không thiết @@ wait_timeout trên MySQL qua: timeout = & # x3e; lựa chọn cơ sở dữ liệu con số không
- Added accessed_columns plugin, ghi âm mà cột đã được đọc cho một trường hợp mô hình
- Sử dụng phiên bản di cư chính xác khi sử dụng IntegerMigrator với: allow_missing_migration_files
- Hãy Dataset # đoàn, #intersect, và #except tự động xử lý các tập dữ liệu với SQL nguyên
- Thêm column_conflicts plugin để tự động xử lý các cột xung đột với tên phương pháp
- Added Model # get_column_value và #set_column_value để nhận / đặt giá trị cột
Điều gì là mới trong phiên bản 4.18.0:
- Hãy Dataset # sản phẩm nào? làm việc khi các dữ liệu được sắp xếp theo một biểu thức không cột.
- Cố định qua một giá trị băm để:. Tùy chọn gắn háo hức
- Hãy đối xử với tất cả các trường hợp ngoại lệ PG :: ConnectionBad như các lỗi ngắt kết nối trong các bộ chuyển đổi postgres.
- Added:. Chính auto_increment thông tin giản đồ cho cột khóa chính
- Cố định xử lý các bảng biểu có trình độ lược đồ trong hiệp hội many_through_many.
Điều gì là mới trong phiên bản 4.16.0:
- Tạo cơ sở dữ liệu # create_table? và #create_join_table? không sử dụng IF NOT EXISTS nếu chỉ số đang được thêm
- Dataset # biệt bây giờ chấp nhận khối hàng ảo
- Nhận lỗi ngắt kết nối trong các bộ chuyển đổi Postgres khi SSL được sử dụng
- Ngừng chuyển đổi "các giá trị mặc định 'để giá trị mặc định con số không trên MySQL
- Added Model # qualified_pk_hash, trả lại một băm với các phím pk có trình độ
- Hãy validates_unique sử dụng một khóa chính đủ điều kiện nếu các số liệu được gia nhập
- Hãy Sequel :: Model.cache_associations = false bỏ qua bộ nhớ cache giản đồ của cơ sở dữ liệu khi tải giản đồ
- Tạo cơ sở dữ liệu # foreign_key_list làm việc trên Microsoft SQL Server 2005
- Hãy create_table với: tùy chọn ngoại hồi trên PostgreSQL
Điều gì là mới trong phiên bản 4.9.0:
- tăng tốc Massive cho phân tích cú pháp mảng PostgreSQL
- Thêm phần mở rộng current_datetime_timestamp, cho trường Time / Ngày giờ hiện tại được literalized như CURRENT_TIMESTAMP
- Nhận thêm hành vi vi phạm chế duy nhất trên SQLite
- Không loại bỏ giá trị cột khi xác nhận thuộc tính lồng nhau cho one_to_ * hiệp hội mà hiệp hội nước ngoài chính là khóa chính của mô hình
- Thêm Dataset # disable_insert_returning trên PostgreSQL cho bỏ qua sử dụng tiềm ẩn của TRỞ LẠI
- Tự động tối ưu hóa Model. [], .with_pk, Và .with_pk! cho các mô hình với các phím hợp
- Tự động tối ưu hóa Model. [] Khi được gọi với một băm
- Nhận KIỂM TRA vi phạm ràng buộc trên các phiên bản mới hơn của SQLite
- Đừng cố gắng để tải háo hức khi gọi Dataset # cột trong các plugin eager_each
- Hỗ trợ: lái xe lựa chọn cho bộ chuyển đổi jdbc, để xác định lớp học lái xe đối với trường hợp getConnection không hoạt động
Điều gì là mới trong phiên bản 4.3.0:
- Nhận một lỗi ngắt kết nối trong jdbc / adapter AS400
- Hãy Dataset # hội đủ điều kiện và Sequel.delay làm việc cùng nhau
- Nhận dạng citext như chuỗi trên PostgreSQL
- phím Hỗ trợ tổng hợp trong các plugin rcte_tree
- phím Hỗ trợ tổng hợp trong các plugin cây
- Hãy Migrator.migrator_class công
- Hãy PostgreSQL trống công việc mảng literalization chính xác trên PostgreSQL & # x3c; 8.4
- mở rộng thêm phần tiếp theo hướng dẫn
- plugins thêm mô hình hướng dẫn
Điều gì là mới trong phiên bản 4.2.0:
- Thêm Cơ sở dữ liệu # supports_partial_indexes? để kiểm tra các chỉ số hỗ trợ một phần.
- Các plugin static_cache tại không cho phép tiết kiệm / phá hủy nếu:. Đông lạnh = & # x3e; lựa chọn sai là không được sử dụng
- Hỗ trợ: đông lạnh = & # x3e; lựa chọn sai lầm trong plugin static_cache, vì có trường hợp mới trở lại thay vì các trường hợp lưu trữ đông lạnh .
- Thêm phần mở rộng cơ sở dữ liệu pg_static_cache_updater cho nghe để thay đổi bảng và cập nhật static_cache cache tự động.
- Thêm phần mở rộng mssql_emulate_lateral_with_apply cho thi đua các truy vấn bên sử dụng CHÉO / OUTER ÁP DỤNG.
- Truy vấn Hỗ trợ bên qua Dataset # bên.
Điều gì là mới trong phiên bản 4.1.1:
- Cố định select_map, select_order_map, và phương pháp single_value trên eager_graphed bộ dữ liệu.
Điều gì là mới trong phiên bản 4.0.0:
- đúng phân tích từ khóa chính tổng hợp trên SQLite 3.7.16 +.
- Nhận một lỗi ngắt kết nối trong jdbc / oracle adapter.
- Added pg_json_ops mở rộng cho chức năng gọi JSON và các nhà khai thác trong PostgreSQL 9.3 +.
- Xử lý không JSON đồng bằng chuỗi, số nguyên, và nổi trong cột PostgreSQL JSON trong phần mở rộng pg_json.
- Dataset # từ bây giờ chấp nhận khối hàng ảo.
- Thêm Cơ sở dữ liệu # refresh_view trên PostgreSQL để hỗ trợ làm mới thể hóa quan điểm.
- Hỗ trợ cơ sở dữ liệu # drop_view:. If_exists tùy chọn trên PostgreSQL
- Hỗ trợ cơ sở dữ liệu # {tạo ra, thả} _view: tùy chọn được vật chất hóa để tạo ra vật chất hóa quan điểm trong PostgreSQL 9.3 + .
- Hỗ trợ cơ sở dữ liệu # create_view: tùy chọn đệ quy để tạo điểm đệ quy trong PostgreSQL 9.3 + .
- Hỗ trợ cơ sở dữ liệu # create_view: cột tùy chọn để sử dụng cột rõ ràng .
Điều gì là mới trong phiên bản 3.47.0:
- Không thất bại vì thiếu proc chuyển đổi trong pg_typecast_on_load Plugin
- Rename PGRangeOp #starts_before và #ends_after để #ends_before và #starts_after
- Add Database # supports_schema_parsing? cho việc kiểm tra các giản đồ phân tích hỗ trợ
- Xử lý hstore loại [] trên PostgreSQL nếu sử dụng pg_array và pg_hstore mở rộng
- Không đặt lại procs chuyển đổi khi tải pg_ * mở rộng
- loại Xử lý miền khi phân tích các lược đồ trên PostgreSQL
- Xử lý các loại tên miền trong các loại hợp trong phần mở rộng pg_row
Điều gì là mới trong phiên bản 3.43.0:
- Di chuyển hỗ trợ #meta_def cho cơ sở dữ liệu, Dataset, và Model để mở rộng meta_def.
- Fix Cơ sở dữ liệu # copy_into trên jdbc / Postgres khi một ngoại lệ xảy ra.
- Thêm core_refinements mở rộng, cung cấp các phiên bản tinh tế của phần mở rộng lõi Sequel của.
- Tạo cơ sở dữ liệu # copy_into nâng cao một DatabaseError nếu cơ sở dữ liệu báo hiệu một lỗi trong các bộ chuyển đổi postgres.
- Define respond_to_missing? nơi method_missing được xác định và đối tượng hỗ trợ respond_to?.
- Cho phép procs lambda với 0 arity như các khối hàng ảo trên Ruby 1.9.
Điều gì là mới trong phiên bản 3.42.0:
- Nếu một ngoại lệ xảy ra trong khi cam kết một giao dịch, nỗ lực rollback.
- kích thước cột Hỗ trợ thiết lập chuỗi mặc định trên một cơ sở cho mỗi cơ sở dữ liệu thông qua default_string_column_size.
- Reset Model.instance_dataset khi mở rộng bộ dữ liệu của mô hình.
- Thực hiện các công việc force_encoding plugin với chuỗi đông lạnh.
- Thêm Cơ sở dữ liệu # làm trên PostgreSQL cho sử dụng câu lệnh DO đang ẩn danh thi khối.
- Removed Model.dataset_methods.
Điều gì là mới trong phiên bản 3.41.0:.
- Thêm bin / phần tiếp theo hướng dẫn sử dụng
- Hãy Dataset # ngược và #reverse_order chấp nhận khối hàng ảo.
- Added Sequel.delay thẩm trì hoãn chung chung.
- Hãy kiểm chứng thực độc đáo xử lý một cách chính xác giá trị con số không.
- Hỗ trợ:. Tùy chọn unlogged cho create_table trên PostgreSQL
Điều gì là mới trong phiên bản 3.39.0:.
- Fix defaults_setter để thiết lập các giá trị mặc định sai
- Fix truy vấn chuỗi nối tiếp trong cơ sở dữ liệu # primary_key_sequence trên PostgreSQL.
- Add Database # copy_into khi sử dụng Postgres adapter với lái xe pg, cho chèn rất nhanh vào các bảng.
- Kết hợp nhiều hoạt động alter_table vào một truy vấn duy nhất mà có thể trên MySQL và PostgreSQL.
- Xử lý bộ hoạt động alter_table trên MySQL và MSSQL nơi các hoạt động sau này phụ thuộc vào những người trước đó.
- Thêm constraint_validations plugin cho kiểm chứng thực tự động của constaints được xác định bằng cách mở rộng.
- Thêm constraint_validations mở rộng để xác định những hạn chế cơ sở dữ liệu tương tự để kiểm chứng thực.
- Add Database # supports_regexp? cho việc kiểm tra hỗ trợ biểu thức chính quy.
- Thêm Sequel.trim cho chức năng nền tảng cắt chéo.
- Thêm Sequel.char_length cho chức năng nền tảng char_length chéo.
- Sửa chữa bộ nhớ đệm của phiên bản máy chủ MySQL.
Điều gì là mới trong phiên bản 3.38.0:
- Phần tiếp theo bây giờ nhận cú đúp (x, y) và đôi (x, y) unsigned loại MySQL.
- Các subadapters nhanh chóng hiện nay yêu cầu nhanh chóng-db- * thay vì bản thân nhanh chóng.
- Add:. Textsize tùy chọn để tinytds adapter để ghi đè lên các TEXTSIZE mặc định
- Hỗ trợ một phương pháp nhận dạng đầu ra trong các bộ chuyển đổi nhanh chóng.
- Thêm Model # to_hash như một bí danh để làm mẫu # giá trị.
- Khi nạp nhiều pg_ * mở rộng thông qua cơ sở dữ liệu # mở rộng, chỉ có reset procs chuyển đổi một lần.
- Không cho phép mô hình typecasting từ chuỗi sang mảng Postgres, hstore, hoặc các loại hỗn hợp.
- Thêm Plugin pg_typecast_on_load cho chuyển đổi các loại PostgreSQL tiên tiến trên tải các {jdbc, làm, nhanh chóng} / Postgres adapter.
- Thực hiện tất cả các adapter để kết nối với PostgreSQL cửa hàng loại procs chuyển đổi.
- Thêm loại oid vào lược đồ cột trên PostgreSQL.
Điều gì là mới trong phiên bản 3.37.0:
- Cho phép xác định cơ sở eager_graph bí danh trên một cuộc gọi mỗi cơ sở sử dụng một AliasedExpression
- Cho phép bin / phần tiếp theo để tôn trọng nhiều tùy chọn -l để đăng nhập cho nhiều tập tin
- đúng xử lý trường hợp SCOPE_IDENTITY là con số không trong các bộ chuyển đổi odbc / MSSQL
- Thêm phần mở rộng pg_interval, trả lại loại khoảng thời gian như trường hợp ActiveSupport :: Thời gian
- Lưu one_to_one đối tượng mới liên quan đến một lần thay vì hai lần trong nested_attributes cắm
- Đừng thêm điều kiện lọc không cần thiết khi đi qua một đối tượng mới cho một phương thức setter one_to_one
- Phân biệt giữa tài liệu tham khảo cột và tài liệu tham khảo phương pháp trong các hiệp hội many_through_many
- Sử dụng: đủ điều kiện = & # x3e;: tùy chọn sâu khi tham gia các bảng trong bộ dữ liệu liên kết mô hình
Điều gì là mới trong phiên bản 3.36.1:.
- Cố định bộ chuyển đổi jdbc khi DriverManager # getConnection không
Điều gì là mới trong phiên bản 3.35.0:
- đúng xử lý phân tích giản đồ cho các bảng trong cơ sở dữ liệu khác trên MySQL.
- Hỗ trợ DSL cho các nhà điều hành modulus (%), tương tự như các toán tử trên bit.
- Cố định các vấn đề thread-an toàn nhất có thể trên hiện thực ruby không GVL.
- Cho phép cắt ngắn của nhiều bảng cùng lúc trên PostgreSQL.
- Cho phép cắt ngắn để có một: thác,: chỉ, và.: Tùy chọn khởi động lại vào PostgreSQL
- Cho phép json và xml serializers để hỗ trợ: tùy chọn mảng trong phương thức lớp to_json để tuần mảng hiện các trường hợp mô hình .
- Thêm Plugin bẩn, giúp tiết kiệm giá trị ban đầu của cột khi giá trị được thay đổi.
Điều gì là mới trong phiên bản 3.34.1:.
- Cố định lỗi trong tối ưu hóa tìm kiếm khóa chính
Điều gì là mới trong phiên bản 3.33.0:
- Thêm khả năng để buộc hoặc giao dịch vô hiệu hóa hoàn toàn trong người di cư sử dụng: tùy chọn use_transactions
- Thêm khả năng để tắt các giao dịch cho sự di cư bằng cách gọi no_transaction bên trong các khối Sequel.migration
- Cho phép đặc biệt lựa chọn mà migrator để sử dụng thông qua TimestampMigrator.apply hoặc IntegerMigrator.apply
- Thêm arbitrary_servers mở rộng để cho phép việc sử dụng các máy chủ độc đoán / mảnh vỡ bằng cách cung cấp một hash của các tùy chọn như các máy chủ
- Thêm phần mở rộng server_block để truy cập phạm vi cơ sở dữ liệu bên trong các khối để một cụ máy chủ mặc định / mảnh
- Tôn trọng: đối chiếu tùy chọn cột trên MySQL
- Sử dụng Mysql2 :: Khách hàng :: FOUND_ROWS để có được số lượng chính xác của hàng xuất trong các bộ chuyển đổi mysql2
- Sử dụng Mysql # thông tin để có được số lượng chính xác của hàng xuất trong các bộ chuyển đổi mysql
- Thực hiện chuyển đổi mô hình với SQL cụ thể phương ngữ sử dụng mặc định phù hợp với trích dẫn định danh
- Tạo danh sách các plugin tự động thiết lập giá trị trường vị trí trên sáng tạo nếu chưa cài đặt
- Add Database # integer_booleans thiết trên SQLite để lưu trữ các phép toán như số nguyên
- cột để định kiểu lưu trữ như là số nguyên / phao trong SQLite bộ chuyển đổi
- Trong các plugin instance_hooks, (trước | sau) _ * _ phương pháp dụ móc hiện trở lại tự
- Xử lý NaN, Infinity, và -Infinity nổi trên PostgreSQL
Điều gì là mới trong phiên bản 3.32.0:
- Hãy serialization_modification_detection việc cắm một cách chính xác với các đối tượng mới và sau khi tiết kiệm đối tượng hiện có.
- Hãy làm mới sau khi tạo mô hình xóa các giá trị deserialized trong các plugin serialization.
- Thêm Dataset # update_ignore trên MySQL, để sử dụng Cập nhật: bỏ qua trong các truy vấn.
- Cho phép select_map / select_order_map mất cả một đối số cột và một khối.
- Sửa lỗi xử lý khối hàng ảo trong select_map / select_order_map khối nếu trả về một mảng.
- Thêm thiết lập Sequel.empty_array_handle_nulls, có thể được thiết lập để sai cho hiệu suất tốt hơn có thể có trên một số cơ sở dữ liệu.
- Thay đổi loại trừ (: b = & # x3e; []) để không trả lại hàng trong đó b là NULL .
- Hỗ trợ ActiveModel 3.2 trong các plugin active_model, bằng cách thêm hỗ trợ cho to_partial_path.
- phương pháp Fix siêu dữ liệu (ví dụ bảng) trên Oracle khi các phương pháp đầu vào nhận dạng tùy chỉnh được sử dụng.
- Fix Cơ sở dữ liệu # chỉ số trên DB2.
Điều gì là mới trong phiên bản 2.5:
- Thêm #set_defaults Dataset và #set_overrides, được sử dụng để xác định phạm vi các giá trị sử dụng trong chèn / báo cáo cập nhật
- Cho phép mô hình để sử dụng các khoản LẠI khi chèn hồ sơ trên PostgreSQL
- Raise Sequel :: DatabaseError thay vì Sequel chung :: lỗi cho các lỗi cơ sở dữ liệu, không nuốt tracebacks
- Sử dụng INSERT ... TRỞ LẠI ... với PostgreSQL 8.2 và cao hơn
- Hãy insert_sql, delete_sql, và update_sql tôn trọng: tùy chọn sql
- Default để chuyển đổi 2 năm chữ số, sử dụng Sequel.convert_two_digit_years = false để lấy lại các hành vi cũ
- Hãy adapter với async_exec sử dụng trình điều khiển pg PostgreSQL, vì vậy nó không chặn toàn bộ thông dịch viên
- Làm cho máy phát điện schema hỗ trợ chính tổng hợp và các phím nước ngoài và ràng buộc duy nhất
- Làm việc với các phiên bản 2008.08.17 của đá quý pg
- Không cho phép lạm dụng chức năng cú pháp SQL với nhiều loại (sử dụng: type = & # x3e;: varchar,: size = & # x3e; 255 thay vì: type = & # x3e;: varchar [255])
- tên Quote chỉ số khi tạo hoặc giảm chỉ số
- Không có phương pháp cột accessor ghi đè cắm phương pháp dụ
- Cho phép xác nhận của nhiều thuộc tính cùng một lúc, với xây dựng trong hỗ trợ cho việc kiểm tra tính độc đáo của nhiều cột
- Trong PostgreSQL adapter, sửa chữa chèn một hàng với một giá trị khóa chính bên trong một giao dịch
- Cho phép before_save và before_update để ảnh hưởng đến các cột cứu bởi save_changes
- Hãy Dataset # single_value làm việc khi vẽ đồ, mà sửa chữa đếm và đánh số trang trên bộ dữ liệu vẽ đồ
Yêu cầu :
- của Ruby 1.8.7 hoặc cao hơn
Bình luận không