- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试弄清楚如何从数据库中提取数据,而无需在每个 ruby 文件的顶部放置连接字符串。
我正在通过我正在组装的一个 Sinatra 小应用程序学习 ruby 的基础知识,该应用程序可以从 MSSQL 数据库中提取数据。
到目前为止,我已经成功地创建了各种简单的 erb 页面,这些页面通过在每个文件的顶部使用以下代码结构来显示来自 MSSQL 数据库的数据:-
<% client = TinyTds::Client.new(:username => 'name', :password => 'password', :dataserver => 'hostname', :database => 'database') %>
<% data = client.execute("SELECT * from tablename") %>
从书籍、指南和在线教程中,我发现基于大量与 PostgreSQL 或 MySQL 数据库有关的配置,在我看来,我需要创建一个中央文件来存储我的连接数据(例如数据库。 yml 文件),然后在我的应用中以某种方式引用它。
这是否正确,我是否应该在我的 main.rb 文件中这样做,以便我的每个 .erb 文件都不需要连接字符串,或者我是否还必须在每个 .erb 文件中引用数据库?
我注意到创建数据库配置变量的引用,例如:-
db_config = YAML.load(File.Open("/path_to_file/database.yml")) [ENV['RAILS_ENV']]
但这显然适合 Rails 应用。
我可以为我的 sinatra 驱动的“应用程序”做类似的事情吗?
谢谢。
最佳答案
这应该有效:
require "sinatra"
require "sinatra/config_file"
config_file 'path/to/config.yml'
DB = TinyTds::Client.new(
:username => settings.name,
:password => settings.password,
:dataserver => settings.hostname,
:database => settings.database
)
get '/' do
@result = DB.do_stuff
haml :index
end
不过,我建议您寻找支持 TinyTDS 的 ORM,并使用它来设置数据库连接和运行查询。我用 Sequel很多I know it supports TinyTDS ,但我相信其他人也会这样做。
我还建议不要将诸如数据库设置之类的内容放入要 checkin 源代码管理的文件中,因为它是敏感信息。生产环境我比较喜欢把这种东西放到环境变量里,开发环境用config文件加载环境变量(为了方便)。使用上面的例子:
DB = TinyTds::Client.new(
:username => ENV["name"],
:password => ENV["password"],
:dataserver => ENV["hostname"],
:database => ENV["database"]
)
这些 env 变量被加载到生产服务器的内存中,这使它们更加安全。对于开发,我在启动 Sinatra 之前加载 YAML 文件,将每个值添加到 ENV var。我并不是说这是一种标准方式,但我就是这样做的。
关于ruby-on-rails - 如何通过 database.yml(或其他)在 ruby/sinatra 中引用 tiny_tds 连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16648623/
首先声明我不是 Ruby 开发人员。我只是想在 Windows x64 上安装 Redmine。我在这里发现了类似的问题,我稍后会链接到。但由于我不是 Ruby 开发人员,所以我不理解答案,也无法将它
今天,tiny_tds 突然不接受多个execute 并返回: C:\>ruby test_use.rb one two C:/test_use.rb:15:in `execute': Attempt
这与此类似 question .然而,answer发布在那个问题上,对我不起作用。我已经在我的 Mac 上安装了 freetds。我在 GemFile 中指定了以下内容。 gem 'tiny_tds'
我正在尝试设置一个新的 mac,但一直无法编译 tiny_tds。我正在运行 OSX Mojave (10.14.6) 并通过 asdf 安装了 ruby 2.4.5。当我尝试捆绑时,安装 tin
在这里,我试图从 MS-SQL Server 2008 获取数据到我在 Ubuntu 10 上的 Rails 应用程序。但是我无法安装 tiny_tds。我按照 github 上给出的步骤进行操作。但
这个问题让我找到了 this question . 我希望能解决我的问题,那里的几个答案详细说明了一些可以帮助安装的配置参数。这些路径不太适合我,所以我修改了它们并最终得到了这个: gem insta
当我运行时: gem install tiny_tds 输出告诉我需要安装 FreeTDS。接下来,它向我展示了一些配置选项,我可能需要一个选项。选项如下: --with-opt-dir
在数据导入脚本中: client = TinyTds.Client.new(...) insert_str = "INSERT INTO [...] (...) VALUE (...)" cli
错误 $ sudo gem install tiny_tds Building native extensions. This could take a while... ERROR: Error i
关闭。 这个问题不符合 Stack Overflow guidelines 。它目前不接受答案。 这个问题似乎与 a specific programming problem, a softwar
require "rubygems" require "tiny_tds" client = TinyTds::Client.new(:username => 'sa', :password => '
我使用 Ruby v2 和 Rails v4 开发了一个 Rails Web 项目。它在我当前的系统中运行良好,当我尝试在另一台 Linux 机器 (Ubuntu 12.4) 中运行该项目时,出现 T
互联网,我不知道该做什么。升级到 Yosemite 后我无法安装 tiny_tds $ gem install tiny_tds Building native extensions. This c
我正在使用 mac os,我想使用 ruby 驱动程序连接到 sql server。我想使用 tiny_tds,但它给出了缺少 free_tds 的错误,但它已经安装了。怎么能过这个? ~ bre
我们试图让 rails 与 Azure 上的 sqlserver 数据库对话,我们使用 openssl 和 libiconv 安装 freeTDS: ./configure --prefix=/usr
我一直在尝试在 OSX 10.6 的 Macbook 上安装 TinyTDS gem。我成功安装了免费 TDS - 通过以下方式确认它可以正常工作: tsql -H SERVER -p 1433 -U
我正在尝试弄清楚如何从数据库中提取数据,而无需在每个 ruby 文件的顶部放置连接字符串。 我正在通过我正在组装的一个 Sinatra 小应用程序学习 ruby 的基础知识,该应用程序可以从
我的问题 我可以采取哪些万无一失的步骤来 100% 使它正常工作?我需要真正的指导,而不是简单的答案或对过程的模糊概念描述。 让我们深入了解一下。似乎某处存在冲突,并且我在 GitHub 上得到了 g
我是一名优秀的程序员,十分优秀!