首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >扩展Ruby Sequel

扩展Ruby Sequel
EN

Stack Overflow用户
提问于 2012-08-25 04:47:44
回答 2查看 512关注 0票数 1

我正在尝试制作一个通过扩展Sequel对象/模块来处理数据库连接的库。但我一直没能通过这个:

代码语言:javascript
复制
require 'sequel'
class Database 
  include Sequel
  def connect()
    self.ado(:conn_string=>"Server=homeServer;Provider=SQLNCLI10;Database=test;Trusted_Connection=yes;")
  end
end
db = LocalDatabase.new()
db.connect()

我收到以下错误: test.rb:5:in connect': undefined methodado‘for # (NoMethodError) from test.rb:10:in’‘

为什么我看不到ado方法?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-08-25 08:19:44

在ruby中,如果你继承了一个类的子类,你可以通过调用超类的单例方法来调用它们作为子类的单例方法,但这不适用于包含/扩展的模块。这是模块与类在方法查找方面的不同之处之一。要理解其中的原因,您需要阅读有关ruby的方法查找和对象模型如何工作的详细信息。

要调用Sequel模块的单例方法,需要使用显式的接收器来调用它们:

代码语言:javascript
复制
require 'sequel'
class Database 
  include Sequel
  def connect()
    Sequel.ado(:conn_string=>"Server=homeServer;Provider=SQLNCLI10;Database=test;Trusted_Connection=yes;")
  end
end
db = LocalDatabase.new()
db.connect()

FWIW,我不推荐使用ado适配器,除非是只读工作负载。由于您似乎要连接到SQL Server,因此我建议您使用tinytds适配器。

票数 2
EN

Stack Overflow用户

发布于 2012-08-25 07:59:16

正在发生的事情是,续集被包括在内,所以它的方法可以作为实例方法使用,我认为你想要扩展,即

代码语言:javascript
复制
require 'sequel'
class Database 
  extend Sequel
  def connect()
    ado(:conn_string=>
    "Server=homeServer;Provider=SQLNCLI10;Database=test;Trusted_Connection=yes;")
  end
end
db = LocalDatabase.new()
db.connect()
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12116432

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档