我遇到了Ruby SQLite的问题。这是我的代码,
require 'socket'
require 'sqlite3'
server = TCPServer.open(1337)
DB = SQLite3::Database.new "./Tavern.db"
loop {
Thread.start(server.accept) do |client|
input = client.gets
input = input.gsub '\n', ''
input = input.split(' ')
case input[0]
when 'register'
stmt = DB.prepare "INSERT INTO Managers (name, job, location, busy)
VALUES (?, ?, ?, 0)"
stmt.bind_params input[1], input[2], client.addr[3]
stmt.execute
when 'request_job'
stmt = DB.prepare "SELECT * FROM Tasks WHERE job = ? AND assigned = 0"
stmt.bind_params input[1]
results = stmt.execute
puts results.next
end
end
}
input[1] = "test"
如果stmt.bind_params input[1]
更改为stmt.bind_params "test"
,则sql查询可以正常工作,如果按原样保留,则不会。我已经检查过以确保“test”和输入[1]与==相等,并在两者上使用.bytes并手动比较。
关于为什么会出现这种情况的任何想法?
答案 0 :(得分:0)
您是否尝试过使用stmt.bind_params( 15, "hello" )
样式语法?
答案 1 :(得分:0)
我遇到过类似的问题。事实证明,我使用的字符串具有与所需编码不同的编码。
检查input[1].encoding
和"test".encoding
的收益率!如果它们不同,请使用force_encoding
- 方法。