草庐IT

PHP、SQL、用户数据库

全部标签

ruby - 如何在 Rails 之外的 Ruby 项目上加载 ActiveRecord 数据库任务?

事件记录3.2.14我想在非RailsRuby项目中使用ActiveRecord。我想让ActiveRecord定义的rake任务可用。我该怎么做?rakedb:create#CreatethedatabasefromDATABASE_URLorconfig/database.ymlforthecurrentRails.env(usedb:create:alltocreatealldbsintheconfig)rakedb:drop#DropsthedatabaseusingDATABASE_URLorthecurrentRails.env(usedb:drop:alltodropal

ruby-on-rails - 查找所有具有重复名称的用户

我的用户有first_name和last_name字段,我需要做一个ruby​​根据名字和姓氏找到所有有重复帐户的用户。例如,我想找到一个可以搜索所有其他用户并查找是否有相同姓名和电子邮件的人。我在想这样的嵌套循环User.all.eachdo|user|//maybeanotherlooptosearchthroughalltheusersandmaybeifamatchoccursputthatuserinanarrayend有没有更好的办法 最佳答案 您可以通过首先找出重复数据的内容来大大缩小搜索范围。例如,假设您要查找多次使

ruby-on-rails - 使用 rolify 查找具有特定角色的所有用户

使用rolify时如何让所有用户都具有特定角色?我尝试了以下但没有帮助:User.with_role:admin我收到以下错误:NoMethodError:undefinedmethod`with_role'for#找不到任何方法来做到这一点。 最佳答案 您可以在User类中使用with_role方法来查找在版本3.1.0中具有角色的所有用户。User.with_role:admin 关于ruby-on-rails-使用rolify查找具有特定角色的所有用户,我们在StackOverfl

ruby - 如何在不保存到文件的情况下将文本数据从 ruby​​ 控制台传递到剪贴板?

我正在尝试将我创建的全局变量中包含的数组传递到我mac上的剪贴板中。它很长,所以我不想在我的控制台上突出显示、复制和粘贴。我想使用嵌入式unix代码,特别是mac笔记本电脑控制台的pbcopy函数,它允许我将文本传递到我的计算机剪贴板,准备粘贴。如果我通过文件保存来做到这一点,我会做这样的事情(在ruby​​中):stringdata=>File.open("temp.txt"){|f|f.write(stringdata)}`cattemp.txt|pbcopy`但我是否可以在不创建临时文件的情况下执行此操作?我相信这是可能的。文本中的所有内容都是可能的。提前感谢您的解决方案

列出了 Ruby gem,但不会加载(用户目录中的 gem,而不是 ruby​​ 目录)

我正在尝试让一些gems在支持ruby​​和一些ruby​​gems的网络主机上运行,​​但不是我需要使用的一些。按照说明我找到了here,我将原始gem位置保留在我的gem路径中,并将我自己的/path/to/my/home/gems添加到~/.gemrcgemhome:/users/home/myuser/gemsgempath:-/usr/local/lib/ruby/gems/1.8-/users/home/mysuser/gems我手动下载了一些gem,并使用gem命令的--local和--install-dir选项进行了安装。然后我做了一个“gem列表”,实际上可以看到我在

ruby-on-rails - Rails 验证用户名中没有空格

我想验证我的用户的用户名没有空格。是否有内置验证可以执行此操作?或者最好的方法是什么。这似乎是一个非常普遍的要求。 最佳答案 我会尝试formatvalidator:validates:username,format:{with:/\A[a-zA-Z0-9]+\Z/}大多数情况下,当您不希望用户名中出现空格时,您也不希望出现其他字符。或者当你真的只需要检查空格时,使用without代替:validates:username,format:{without:/\s/}完整文档:http://api.rubyonrails.org/cl

ruby - 哪个查询去了哪个数据库的 ActiveRecord 日志

在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo

ruby-on-rails - 为 Rails 迁移加载种子数据

我有一个现有的数据库,我正在将以前的“NULL”列转换为具有默认值的列(并使用所述默认值填充该列)。但是,该值是我需要创建的记录的ID。如果我将此记录放入db/seeds.rb,它不会运行,因为db/seeds.rb在迁移之后运行——但迁移需要种子数据。如果我在迁移中保留记录创建,那么如果我使用db:load创建新数据库,我将不会获得记录。除了在db/seeds.rb和迁移中复制它之外,还有更好的方法吗?谢谢! 最佳答案 虽然我能理解您希望保持DRY并且不必在migration和seeds.rb中都写这个,但我认为您应该在两个地方都

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一