草庐IT

ruby-on-rails - 如何在 Rails 脚手架生成器上强制使用单数表名?

我正在使用遗留数据库并需要创建一些CRUD。我如何使用scaffold生成器并告诉他表的确切名称以避免复数化过程?表格也是西类牙语。 最佳答案 您可以只使用ActiveRecord::Base.table_name=方法手动设置表名。因此,在您的模型中您可以:classOrderDetail 关于ruby-on-rails-如何在Rails脚手架生成器上强制使用单数表名?,我们在StackOverflow上找到一个类似的问题: https://stackove

ruby-on-rails - Rails Postgresql 多个模式和相同的表名

我在两个不同的模式中有两个表,例如案例和事件。在每个模式中我都有基本表events.basiccases.basic这个表有关系:events.basic有一个cases.basic(cases.basic有多个events.basic)我的尝试失败了:文件cases_basic.rbclassCasesBasic'EventsBasic',:foreign_key=>'case_id'end文件events_basic.rbclassEventsBasic'CasesBasic',:foreign_key=>'case_id'end环境:Ruby1.9.3、Rails3.1.3、ge

ruby-on-rails - ActiveRecord 中的表名损坏错误

在使用ActiveRecord时,我们偶尔会遇到PG::UndefinedTable错误。关联表名称有些损坏,我经常看到Cancelled附加到表名的末尾。例如:ActiveRecord::StatementInvalid:PG::UndefinedTable:ERROR:relation"fooCancell"doesnotexistActiveRecord::StatementInvalid:PG::UndefinedTable:ERROR:relation"Cancelled"doesnotexistActiveRecord::StatementInvalid:PG::Undef

ruby-on-rails - 如何将 ActiveRecord 表名转换为模型类名

是否有可能将ActiveRecord表名正确转换为模型类名?我发现了一个黑客defmodel_for_table(table_name)table_name.classify.constantizeend但是由于我们对我们的许多模型使用set_table_name,所以这行不通。有什么办法吗? 最佳答案 我做到了!这将以“table_name”=>“model_class_name”的形式返回一个散列。Hash[ObjectSpace.enum_for(:each_object,class编辑:更好的版本(仅适用于Rails3):H

ruby - 如何确定 Rails 3 模型类中的表名

我想在模型方法中获取表名。我found应该有方法table_name但是当我尝试调用它时我得到NameErrorException:undefinedlocalvariableormethod`table_name'。显然不存在:ppmethods.grep(/^ta.*/)["table_name_prefix?","table_name_suffix?","taint","taguri","taguri=","tainted?","table_name_prefix","table_name_suffix","tap"]如何获得“真实的”表名(无小写-复数技巧)?谢谢

ruby-on-rails - 从 ActiveRecord 获取表名

我使用ActiveRecord::Base.set_table_name在动态创建的ActiveRecord类上设置我的表名。现在我需要知道以后如何获得该值。api文档没有提及如何执行此操作。此外,我无法从ActiveRecord类名派生出表名,因为它们的键控与表名不同。这是我正在做的一个更好的例子table_klass=Class.new(ActiveRecord::Base)ActiveRecord::Base.const_set(const_name,table_klass)app=@apptable_klass.class_evaldoafter_savedo@@channel

mysql - 参数化表名

这是我的问题:我想检查名称已参数化的表中的行,例如table_X。X的值来自另一个表,因此例如在我的主表中,我有一个列c_id和一个X列,要连接的表的名称为table_X,它毫无疑问存在,并且它有我将加入的同一列c_id,以检查该表中是否有c_id的值。我试过View,但没有成功,因为我无法在View中放置参数化表名。我可以参数化where子句和其他东西,但不能参数化表名。我试过一个程序,用SET@q=CONCAT('selectblablafromtable_',X);PREPAREstmtFROM@q;EXECUTEstmt;但是程序不能返回值,而我需要它,因为我需要知道参数化表中

database - SQLX "missing destination name"在结构标记中使用表名时

问题是当我对对象使用结构标签时,它们无法正常工作。我以前做过同样的事情但没有遇到任何问题的项目,但我不明白为什么。示例:这不起作用:typeCategorystruct{IDint`json:"id"db:"category.id"`Namestring`json:"name"db:"category.name"`Descriptionstring`json:"description"db:"category.description"`}收到错误:*[]Category中缺少目的地名称ID这很好用:typeCategorystruct{IDint`json:"id"db:"id"`Na

postgresql - Go database/sql 改变表名的大小写

我正在尝试使用database/sql和github.com/lib/pqPostgres驱动程序查询数据库。我遇到的错误是:pq:relation"itemprices_itemsale"doesnotexist但是看看我的查询:rows,err:=db.Query("SELECT*FROM\"itemPrices_itemsale\"LIMIT10")您会注意到表名中的大写“P”。我已经了解到,如果没有引用,Postgres会将名称折叠成小写字母。我引用了我的表名,所以我不太确定为什么会这样。我相当确定这就是问题所在,因为我能够使用类似Python程序中的表名查询表,并且一切都按预

SQLBoiler 获取 Join 的表名

我正在尝试遵循sqlboiler(https://github.com/volatiletech/sqlboiler)中的示例。但是,我找不到一种方法来获取内连接查询中使用的表名。users,err:=models.Users(Select("id","name"),InnerJoin("credit_cardsconc.user_id=users.id"),Where("age>?",30),AndIn("c.kindin?","visa","mastercard"),Or("emaillike?",`%aol.com%`),GroupBy("id","name"),Having("