ZetCode

在 SQLite 中使用 Ruby 进行 SQL 查询

最后修改于 2020 年 7 月 6 日

我们已经建立了与数据库的连接。现在我们将修改并从数据库中获取数据。

数据使用 SELECT 语句从数据库中检索。 在 SQLite Ruby 模块中,首先我们使用 prepare 方法准备 SQL 语句。 SQL 字符串被发送到数据库引擎,该引擎检查语句的有效性、语法以及某些数据库中用户执行特定查询的权限。 如果一切正常,则会向 Ruby 脚本返回一个语句对象。 下一步是调用 execute 方法。 该方法在数据库中执行查询。 数据被检索。

Ruby SQLite 模块有几种从数据库表中获取数据的方法。 在准备并执行了 SQL 语句之后,我们可以遍历返回的数据。

获取数据

在第一个示例中,我们从 Cars 表中获取一行数据。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.new "test.db"
    
    id = 1
    
    stm = db.prepare "SELECT * FROM Cars WHERE Id=?"
    stm.bind_param 1, id
    rs = stm.execute
    
    row = rs.next
    
    puts row.join "\s"
    
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    stm.close if stm
    db.close if db
end

在示例中,我们执行所有步骤以从 Cars 表中获取第一行数据。

stm = db.prepare "SELECT * FROM Cars WHERE Id=?"

SELECT 语句使用 prepare 方法进行准备。 返回一个语句对象。

stm.bind_param 1, id

一个参数被绑定到语句中的占位符。

rs = stm.execute

语句被执行。 返回一个 ResultSet 对象。

row = rs.next

我们从结果集中获取下一行数据。 由于我们只想获取一行数据,因此我们调用 next 方法一次。

puts row.join "\s"

该行是一个 Ruby 数组。 使用 join 方法将三个字段用空格字符连接起来形成一行。

$ ./fetch.rb
1 Audi 52642

这是示例的输出。

在下面的示例中,我们将获取五行数据。 我们将 next 方法放入一个 while 循环中。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.open "test.db"
        
    stm = db.prepare "SELECT * FROM Cars LIMIT 5"
    rs = stm.execute
    
    while (row = rs.next) do
        puts row.join "\s"
    end
        
    
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    stm.close if stm
    db.close if db
end

在此脚本中,我们连接到数据库并获取 Cars 表的 5 行数据。

stm = db.prepare "SELECT * FROM Cars LIMIT 5"

这是用于获取 5 行数据的 SQL 语句。

while (row = rs.next) do
    puts row.join "\s"
end

next 方法放在 while 循环内。 它从结果集中返回下一行数据。 如果没有更多行,该方法将返回 nil,while 循环将终止。

我们可以使用 each 方法从结果集中获取数据。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.open "test.db"
        
    stm = db.prepare "SELECT * FROM Cars LIMIT 5"
    rs = stm.execute
    
    rs.each do |row|
        puts row.join "\s"
    end
            
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    stm.close if stm
    db.close if db
end

再次,我们从 Cars 表中选择五行数据。

rs.each do |row|
    puts row.join "\s"
end

我们使用 each 方法迭代结果集。

下一个示例显示数据库对象的 execute 方法。 这是一个方便的方法,可以节省一些击键次数。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.open "test.db"
        
    rows = db.execute "SELECT * FROM Cars LIMIT 5"
        
    for row in rows do
        puts row.join "\s"
    end
            
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    db.close if db
end

该示例从 Cars 表中选择并打印五行数据。

rows = db.execute "SELECT * FROM Cars LIMIT 5"

在这里,我们一步完成了两项工作。 我们准备语句并执行它。 该方法将数据作为 Ruby 数组返回。

for row in rows do
    puts row.join "\s"
end

我们从 Ruby 数组中打印数据。

到目前为止,我们已经看到了以 ResultSet 或数组形式返回的数据。 下一个示例将以哈希数组的形式返回数据。 这样,我们可以通过其列名来标识字段值。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.open "test.db"
    db.results_as_hash = true
        
    ary = db.execute "SELECT * FROM Cars LIMIT 5"    
        
    ary.each do |row|
        printf "%s %s %s\n", row['Id'], row['Name'], row['Price']
    end
             
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    db.close if db
end

在示例中,我们通过它们的列名获取字段。

db.results_as_hash = true

我们将 results_as_hash 属性设置为 true。 所有行都将作为 Hash 对象返回,其中列名作为键。

ary.each do |row|
    printf "%s %s %s\n", row['Id'], row['Name'], row['Price']
end

我们通过其列名获取字段。

$ ./fetch_hash.rb
1 Audi 52642
2 Mercedes 57127
3 Skoda 9000
4 Volvo 29000
5 Bentley 350000

我们看到该示例的输出。

获取一行或一个值

Ruby SQLite 模块有两个方便的方法用于检索一行或一个值。 在第一个示例中,我们将从表中获取一行数据。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.open "test.db"
      
    row = db.get_first_row "SELECT * FROM Cars WHERE Id=1"       
    puts row.join "\s"
    
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    db.close if db
end

我们获取 Cars 表的第一行数据。

row = db.get_first_row "SELECT * FROM Cars WHERE Id=1" 

get_first_row 方法获取第一行并丢弃所有其他行。

puts row.join "\s"

该行被打印到控制台。

$ ./fetchrow.rb
1 Audi 52642

在这里,我们看到了 fetchrow.rb 示例的输出。

在最后一个示例中,我们选择一个值。

#!/usr/bin/ruby

require 'sqlite3'

begin
    
    db = SQLite3::Database.open "test.db"
      
    val = db.get_first_value "SELECT Price FROM Cars WHERE Name='Bentley'"       
    puts val
    
rescue SQLite3::Exception => e 
    
    puts "Exception occurred"
    puts e
    
ensure
    db.close if db
end

我们为特定的汽车选择一个价格。

val = db.get_first_value "SELECT Price FROM Cars WHERE Name='Bentley'"      

使用 get_first_value 方法,我们选择一行的特定字段。 在我们的例子中,它是 Bentley 汽车的价格。

$ ./fetchvalue.rb
350000    

这是输出。

在本 SQLite Ruby 教程中,我们演示了如何使用各种方法从数据库中获取数据。