Ruby 连接MySQL数据库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 使用Ruby连接数据库的过程还真的是坎坷,于是写点文字记录一下。简介Ruby简介RubyGems简介包管理之道比较著名的包管理举例细说gem常用的命令准备驱动下载dbimysqlmysql2MySQL的CC连接器...

使用Ruby连接数据库的过程还真的是坎坷,于是写点文字记录一下。

简介

Ruby简介

Ruby是一种纯粹的面向对象编程语言。它由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)创建于1993年······

简介就介绍到这么多了,反正也没人愿意看这些文字。下面着重讲下一个小结。

RubyGems简介

包管理之道

在说RubyGems之前,我们来谈一谈关于包管理。在没有包管理软件之前,我们要想完成一个库或者软件的安装,要处理好这些东西之间的依赖以及版本关系等等,总之,对于新手而言,这无疑是加大了学习的曲线。而包管理的诞生,把我们从繁琐复杂的安装过程中解放了出来。

比较著名的包管理举例

  • 作为一个程序员,想必都接触过Linux系统,在其之上的包管理软件也有很多,比如Ubuntu的apt-get,Redhat的rpm,yum;Debian系列的dpkg等等;

  • 或者Node.js语言的npm;

  • Python 的easy_install 或者久负盛名的pip

  • 还有今天我们要说的Ruby 中的gem

细说gem

Gem 是 Ruby 模块 (叫做 Gems) 的包管理器。其包含包信息,以及用于安装的文件。

其原理是:

Gem通常是依照”.gemspec”文件构建的,包含了有关Gem信息的YAML文件。Ruby代码也可以直接建立Gem,这种情况下通常利用Rake来进行。

常用的命令

gem命名和Python的pip很相似,其实大部分的包管理使用起来都很类似,现简要的介绍一下吧。

  • 安装

    gem install mygem

  • 卸载

    gem uninstall mygem

  • 列出已经安装的gem

    gem list –local

  • 列出可用的gem

    gem list –remote

  • 为所有的gems创建RDoc文档

    gem rdoc -all

  • 下载一个gem,但不安装

    gem fetch mygem

  • 从可用的gems中搜索gem

    gem search STRING –remote

准备

要想使用Ruby连接数据库,我们就需要跨进程操作了。所以我们必须借助驱动来完成这两个工作模式完全不同的进程。那么,交给驱动来解决这个问题吧。

驱动下载

连接MySQL数据库,常见的几种方式如下。

dbi

图解分层

这就是DBI的工作原理,我们只需要调用封装好了的API就可以实现对不同数据库的操作,这对于移植来说会很方便。

Administrator@WIN-5APATS8G3U6 MINGW64 /d/Software/ruby/Ruby23-x64/lib/ruby/gems/2.3.0/gems
$ gem install dbi
Successfully installed dbi-0.4.5
Parsing documentation for dbi-0.4.5
Done installing documentation for dbi after 1 seconds
1 gem installed

如此便成功安装了DBI模块。具体参照DBI 模块

mysql

不巧的是,我在安装mysql模块的时候出现了下面的这些个问题。根据错误提示我们需要使用dev工具来安装才行,但是mysql模块安装不成功并不影响我们对数据库的操作,所以这个问题就先放放一放吧。

$ gem install mysql
ERROR:  Error installing mysql:
        The 'mysql' native gem requires installed build tools.

Please update your PATH to include build tools or download the DevKit
from 'http://rubyinstaller.org/downloads' and follow the instructions
at 'http://github.com/oneclick/rubyinstaller/wiki/Development-Kit'

mysql2

Ruby 连接 Mysql 更高效的驱动 mysql2,目前也推荐使用这种方式连接 MySql。
安装过程同样是很简单。

gem install mysql2

$ gem install mysql2

Successfully installed mysql2-0.4.4-x64-mingw32
Parsing documentation for mysql2-0.4.4-x64-mingw32
Done installing documentation for mysql2 after 0 seconds
1 gem installed

MySQL的C/C++连接器

libmysql.dll 文件是MySQL的动态链接库文件,缺少此文件数据库无法正常工作。将这个文件 拷贝到 Ruby/Bin目录中,或者C:\windows\system32目录也可。

下载地址

点击msi版本的安装即可。

测试环境

基本上准备工作完成了,下面说一下我的实验环境。

  • OS: Windows 7 旗舰版
  • Ruby版本: ruby 2.3.1p112 (2016-04-26 revision 54768) [x64-mingw32]
  • IDE: RubyMine 2016.2
  • MySQL版本: MySQL 5 .7

代码测试

下面真正开始使用Ruby操作MySQL数据库。根据Unix思想“做一件事,就用最好的方式,做到最好”,于是下面我就采用mysql2模块来操作了。

连接数据库

首先是连接数据库。如下:

require 'mysql2'

client = Mysql2::Client.new(
    :host     => '127.0.0.1', # 主机
    :username => 'root',      # 用户名
    :password => '123456',    # 密码
    :database => 'test',      # 数据库
    :encoding => 'utf8'       # 编码
    )

里面的值视自己的情况而定。

CRUD

使用Ruby操作数据库实现增删改查也是很方便的一件事,至少和Python一样简洁。

Select

require 'mysql2'

client = Mysql2::Client.new(
    :host     => '127.0.0.1', # 主机
    :username => 'root',      # 用户名
    :password => 'mysql',    # 密码
    :database => 'fams',      # 数据库
    :encoding => 'utf8'       # 编码
)

result = client.query("Select * from dog")
result.each do |item|
  puts "In row :#{item['id']} the dog's name is :#{item['name']}"
end

获得的结果如下:

D:\Software\ruby\Ruby23-x64\bin\ruby.exe -e $stdout.sync=true;$stderr.sync=true;load($0=ARGV.shift) E:/Code/ruby/helloworld/hello.rb
{"VERSION()"=>"5.7.13-log"}
In row :1 the dog's name is :lachang
In row :2 the dog's name is :hashiqi
In row :3 the dog's name is :samoyed
In row :4 the dog's name is :wolf

Process finished with exit code 0

Delete

require 'mysql2'

client = Mysql2::Client.new(
    :host     => '127.0.0.1', # 主机
    :username => 'root',      # 用户名
    :password => 'mysql',    # 密码
    :database => 'fams',      # 数据库
    :encoding => 'utf8'       # 编码
)

client.query("delete from dog where id = 5")
result = client.query("Select * from dog")

result.each do |item|
  puts "In row :#{item['id']} the dog's name is :#{item['name']}"
end

结果如下:

In row :1 the dog's name is :lachang
In row :2 the dog's name is :hashiqi
In row :3 the dog's name is :samoyed
In row :4 the dog's name is :wolf

Update

require 'mysql2'

client = Mysql2::Client.new(
    :host     => '127.0.0.1', # 主机
    :username => 'root',      # 用户名
    :password => 'mysql',    # 密码
    :database => 'fams',      # 数据库
    :encoding => 'utf8'       # 编码
)

client.query("update dog set name='郭璞' where id = 2")
result = client.query("Select * from dog")

result.each do |item|
  puts "In row :#{item['id']} the dog's name is :#{item['name']}"
end

获得的结果为:

In row :1 the dog's name is :lachang
In row :2 the dog's name is :郭璞
In row :3 the dog's name is :samoyed
In row :4 the dog's name is :wolf

Insert

require 'mysql2'

client = Mysql2::Client.new(
    :host     => '127.0.0.1', # 主机
    :username => 'root',      # 用户名
    :password => 'mysql',    # 密码
    :database => 'fams',      # 数据库
    :encoding => 'utf8'       # 编码
)

client.query("insert into dog(name) values('哈士奇')")
result = client.query("Select * from dog")

result.each do |item|
  puts "In row :#{item['id']} the dog's name is :#{item['name']}"
end

处理结果为

In row :1 the dog's name is :lachang
In row :2 the dog's name is :hashiqi
In row :3 the dog's name is :samoyed
In row :4 the dog's name is :wolf
In row :5 the dog's name is :哈士奇

仿PreparedStatement

用过JDBC的PreparedStatement的API的都知道其好处,所以我们在这里要模拟一下。

“假冒伪劣版”

name = "CSDN 博客小札"
client.query("update dog set name='"+name+"' where id = 2")
result = client.query("Select * from dog")

“假冒伪劣进阶版”

或者这样的:

name = "CSDN 博客小小札"
client.query("update dog set name='#{name}' where id = 2")
result = client.query("Select * from dog")

实际上我们不难看出,其还是对SQL语句的拼凑,并不是真正的Prepared方式。所以在书写sql语句的时候要格外用心啊。

处理结果集

其实在上面的CRUD操作中我们就可以看到。我们经常采用遍历操作来获取结果集中的详细信息。我们在操作的时候一定是需要知道结果集中的数据字段信息的,这样才能较好的实现我们的需求。

表结构

本例中表结构的详细信息为:

mysql> desc dog;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(10)     | NO   | PRI | NULL    | auto_increment |
| name  | varchar(30) | NO   |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.12 sec)

结果集遍历

result.each do |item|
  puts "In row :#{item['id']} the dog's name is :#{item['name']}"
end

如此即可,遵守其规则之后,我们也会发现,不过如此了。

总结

对于Ruby而言,貌似真的是不太适合在Windows下学习,毕竟资料方面真的是太少了。而且有很多操作没有相关的命令,也让人很沮丧。不过我相信,只要用心学,就能学好Ruby的。

与君共勉 :-)

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
存储 Go API
使用GoFrame连接和操作TDengine时序数据库
通过使用GoFrame框架和TDengine Go驱动,我们可以方便地连接和操作TDengine时序数据库。无论是插入、查询还是分析时序数据,都可以通过简单的API调用来实现。GoFrame提供了强大的Web开发功能,结合TDengine的高性能时序数据存储和查询能力,可以构建高效、可扩展的时序数据应用。
|
1月前
|
NoSQL 关系型数据库 PHP
php连接数据库
要使用PHP连接PolarDB或MongoDB数据库,需先准备连接信息,并编写相应代码。对于PolarDB,需设置主机地址、端口、数据库名及凭据,使用`pg_connect`函数建立连接;而对于MongoDB副本集,需安装MongoDB PHP驱动,通过`MongoDB\Client`连接指定的副本集实例。请确保替换示例代码中的占位符为实际值,并正确配置副本集名称和主机信息。更多详细信息与示例代码,请参考相关链接。
135 72
|
9天前
|
关系型数据库 MySQL 数据库
6-2|测试连接数据库的命令
6-2|测试连接数据库的命令
|
9天前
|
SQL 关系型数据库 MySQL
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
本文介绍了在ThinkPHP6框架中如何连接和使用数据库进行增删改查操作。内容包括配置数据库连接信息、使用Db类进行原生MySQL查询、find方法查询单个数据、select方法查询数据集、save方法添加数据、insertAll方法批量添加数据、insertGetId方法添加数据并返回自增主键、delete方法删除数据和update方法更新数据。此外,还说明了如何通过数据库配置文件进行数据库连接信息的配置,并强调了在使用Db类时需要先将其引入。
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
|
9天前
|
SQL 关系型数据库 数据库连接
php连接数据库之PDO,PDO的简单使用和预定义占位符的使用以及PDOStatement对象的使用,占位符的不同形式,bindValue和bindParam绑定预定义占位符参数的区别
本文介绍了PHP中PDO(PHP Data Objects)扩展的基本概念和使用方法。内容包括PDO类和PDOStatement类的介绍,PDO的简单使用,预定义占位符的使用方法,以及PDOStatement对象的使用。文章还讨论了绑定预定义占位符参数的不同形式,即bindValue和bindParam的区别。通过具体示例,展示了如何使用PDO进行数据库连接、数据查询、数据插入等操作。
php连接数据库之PDO,PDO的简单使用和预定义占位符的使用以及PDOStatement对象的使用,占位符的不同形式,bindValue和bindParam绑定预定义占位符参数的区别
|
9天前
|
SQL 关系型数据库 MySQL
php学习笔记-连接操作mysq数据库(基础)-day08
本文介绍了PHP中连接操作MySQL数据库的常用函数,包括连接服务器、设置字符集、关闭连接、选择数据库、结果集释放、获取影响行数以及遍历结果集等操作。通过书籍查询的实例演示了如何使用这些函数进行数据库操作,并提供了一个PHP操纵MySQL数据库的模板。
php学习笔记-连接操作mysq数据库(基础)-day08
|
13天前
|
SQL 关系型数据库 MySQL
MySQL C连接与使用
【9月更文挑战第21天】在 MySQL 中,可以通过 C 语言连接和操作数据库。首先需安装 MySQL 服务器及 C 开发库,然后在程序中包含必要头文件,初始化连接对象,并使用实际参数建立连接。执行 SQL 语句时,需替换表名等变量,获取并遍历结果集。最后,释放资源并关闭连接。过程中应注意错误处理、内存管理和安全性,以及性能优化。此方式适用于高效数据存储和检索的应用程序。
|
12天前
|
SQL JavaScript 关系型数据库
Node服务连接Mysql数据库
本文介绍了如何在Node服务中连接MySQL数据库,并实现心跳包连接机制。
26 0
Node服务连接Mysql数据库
|
2月前
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
19 7
|
10天前
|
关系型数据库 MySQL 数据库
docker启动mysql多实例连接报错Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
docker启动mysql多实例连接报错Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
39 0
下一篇
无影云桌面