在没有数据库表或者列的情况下新建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 连接)?

如何在不将数据输入自动编号列的情况下将数据插入 MS Access 表?

我可以在不返回条件列的情况下进行左连接吗?

在不使用第三个变量或表的情况下交换表中两列的值