在没有数据库表或者列的情况下新建model;rails ,ruby, rack
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在没有数据库表或者列的情况下新建model;rails ,ruby, rack相关的知识,希望对你有一定的参考价值。
因为在某些情况下要使用不存在的列,或者是要新建一个虚拟的model
可以在models下的concerns下新建tableless.rb,代码如下:
module Tableless
def self.included(base)
base.extend(ClassMethods)
base.send(:include,InstanceMethods)
end
module InstanceMethods
def save(validate = true)
validate ? valid? : true
end
end
module ClassMethods
def column(name, sql_type = nil, default = nil, null = true)
columns << ActiveRecord::ConnectionAdapters::Column.new(name.to_s, default,
sql_type.to_s, null)
end
def columns
@columns ||= [];
end
end
end
在model中的使用如下:
class Notice < ActiveRecord::Base
include Tableless
column :code, :integer
column :message, :string
attr_accessor :code, :message
end
以上是关于在没有数据库表或者列的情况下新建model;rails ,ruby, rack的主要内容,如果未能解决你的问题,请参考以下文章
如何在不先定义表中的列的情况下将数据加载到 PostgreSQL 中?
如何在没有连接列的情况下映射一对一关系(实体通过它们的 ID 连接)?