неопределенный метод execute для nil: NilClass - PullRequest
0 голосов
/ 03 июля 2018

Я делаю инструмент в ruby, который может взаимодействовать с базами данных. Я использую amalgalite в качестве адаптера для sqlite3.

Код:

require 'amalgalite'
# this is class RQuery
class RQuery
  def db_open(db_name)
    @db = Amalgalite::Database.new "#{db_name}.db"
    make_class
  end

  def exec_this(query)
    @db.execute(query)
  end

  def make_class
    tables_list = exec_this("select name from sqlite_master where type='table'")
    tables_list.each do |table|
      @class_created = Object.const_set(table[0].capitalize, Class.new)
      @class_created.class_eval do
        define_singleton_method :first do
          RQuery.new.exec_this("select * from #{table[0]} order by #{table[0]}.id ASC limit 1")
        end
      end
    end
  end

  def eval_this(input)
    instance_eval(input)
  end

  def code
    print '>>'
    input = gets
    exit if input =~ /^q$/
    puts eval_this(input)
    code
  end
end

Теперь, когда я запускаю код, все работает нормально, пока я не позвоню table_name.first

выдаёт вывод

vbhv@fsociety ~/git/R-Query/bin $ ruby main.rb 
Enter the code or q for quit
>>db_open('vbhv')
users
persons
people
programmers
>>Users.first
/home/vbhv/git/R-Query/lib/r-query.rb:36:in `instance_eval': undefined  method `execute' for nil:NilClass (NoMethodError)
Did you mean?  exec
from /home/vbhv/git/R-Query/lib/r-query.rb:29:in `block (3 levels) in make_class'
from (eval):1:in `eval_this'
from /home/vbhv/git/R-Query/lib/r-query.rb:36:in `instance_eval'
from /home/vbhv/git/R-Query/lib/r-query.rb:36:in `eval_this'
from /home/vbhv/git/R-Query/lib/r-query.rb:43:in `code'
from /home/vbhv/git/R-Query/lib/r-query.rb:44:in `code'
from /home/vbhv/git/R-Query/lib/r-query.rb:44:in `code'
from main.rb:4:in `<main>'

Теперь функция execute, о которой идет речь, находится внутри amalgalite. Что я здесь не так делаю ?? Заранее спасибо!

1 Ответ

0 голосов
/ 05 июля 2018

Проблема в том, что новый класс, созданный динамически, не знает о переменной соединения '@db'. Следовательно, код решает проблему.

@class_created.instance_variable_set (: @ database, @db)

Большое спасибо Джагдип Сингх .

...