草庐IT

MySQL:如果行不存在则插入行?

全部标签

ruby-on-rails - rails friendly_id 并检查条目是否存在

如何检查friendly_id条目在获取之前就存在?例如:defbook@book=Book.find(params[:book_id])end没关系,但我想先检查friendly_id是否存在,例如:defbookifBook.exists?(params[:book_id])@book=Book.find(params[:book_id])else#404notfoundend 最佳答案 对于friendly_idgem的最新版本,您可以说:Book.friendly.exists?params[:book_id]

ruby-on-rails - Rails 错误 : Unable to access log file. 请确保/home.../log/development.log 存在并且是 chmod 0666

我正在尝试将db2数据库迁移到RubyonRails,但是当我运行railsgscaffold时,我得到了这个:Rails错误:无法访问日志文件。请确保/home/.../log/development.log存在并且是chmod0666。日志级别已提高到WARN,输出定向到STDERR,直到问题得到解决。我检查过,我的development.log不存在!我不确定为什么,因为我在安装过程中遵循了每一步,但我的文件仍然不存在。我怎样才能创建它?我已经尝试卸载并重新安装Rails,但问题仍然存在。 最佳答案 也许只做它要求你做的事?:

ruby - 如何在 Ruby 中插入或更新之前转义字符串

在ruby​​中,ActiveRecord不提供更新和插入sql的动态绑定(bind),当然我可以使用原始sql,但是需要保持连接,所以我想知道是否有更简单的方法在执行之前转义更新或插入sql像下面的代码:ActiveRecord::Base.connection.insert(sql)我想我可以用gsub写代码,但我知道是否有现成的方法来做。 最佳答案 在Rails>=3.2.5中,以下对我有用:evil_input='"\';%#{}\"foo'ActiveRecord::Base.connection.quote(evil_i

ruby-on-rails - 如果只有一个存在,是否有用于返回第一个数组元素的 ruby​​ 习惯用法?

如果数组只包含一个值,我想返回数组的第一个元素。目前,我使用:vals.one??vals.first:vals.presence因此:vals=[];vals.one??vals.first:vals.presence#=>nilvals=[2];vals.one??vals.first:vals.presence#=>2vals=[2,'Z'];vals.one??vals.first:vals.presence#=>[2,"Z"]是否有内置的东西可以做到这一点,或者是否有更好的设计考虑?我的用例是特定的,涉及知道从方法(将实现上述代码)中期望什么的演示者。如果这些演示者将所有返回

ruby - 为什么在 Ruby 中存在两种访问模块函数的方式?

moduleAdefself.funcputs"func"endend>>A.funcfunc>>A::funcfunc为什么.和::都存在?为什么不仅是.? 最佳答案 作用域解析运算符(::)可以解析常量、实例方法和类方法,因此只要我们在正确的位置查找,我们就可以将该运算符用于基本上任何方法。此外,由于方法“func”被定义为模块A的类方法(通过self.func,类似于“静态”方法)它直接属于模块(即本身是一个对象)所以它可以用点运算符调用,模块作为接收者。请注意,模块A的实例对“func”没有任何可见性,因为它是一个类方法:a

ruby-on-rails - 如何使用 rspec 模拟/伪造文件的存在?

这是我的:it"shouldbeabletogetavaliddirectorypath"do@asset.some_file_path.should=="/something/test.jpg"end问题是如果不存在文件,some_file_path返回“/not_here_yet.jpg”。defsome_file_pathifFile.exists(self.my_image_path)returnmy_image_pathelsereturn"/not_here_yet.jpgendend我真的不想在我的测试中创建一个新文件。我有办法伪造该文件的存在吗?我在想一些事情:it"s

ruby - Emacs Ruby Electric 不插入结束

我通过ELPA安装了RubyElectric模式。我访问了一个ruby文件~/test.rbC-hm显示ruby​​electric模式和字体锁定已启用,请参阅下面的输出Enabledminormodes:Auto-CompressionAuto-EncryptionBlink-CursorColumn-NumberDelete-SelectionFile-Name-ShadowGlobal-Font-LockGlobal-LinumIswitchbLine-NumberMenu-BarMouse-WheelShell-DirtrackTooltipTransient-Mark但是当我

ruby-on-rails - MySql 上的 Rails 复选框存储为 null 或零

在我的Rails应用程序中,我有一个项目列表(如任务列表),每个项目都有几个复选框来设置参数。当我提交表单时,选中的框在数据库中存储为零,未选中的存储为空。问题是:有办法配置吗?将数据存储在更传统的0或1上,因为我认为将null存储为false并将0存储为true有点令人困惑,特别是如果另一个应用程序(如C应用程序)需要读取数据。 最佳答案 假设您正在使用的属性是club_member,如“您是club_member吗?”。请注意,在Ruby/Rails中,它现在的工作方式是,ifmodel.club_member如果未选中(值为n

ruby-on-rails - 如何验证 Rails Controller 中的存在和正则表达式格式?

我正在尝试验证电子邮件地址..它是否存在..以及它是否符合正则表达式标准(/xyz/)。我真的需要在rails的Controller或View级别上执行此操作,因为我打算为我的应用程序转储ActiveRecord,因为我计划稍后使用nosql数据库。有什么提示吗?有什么建议吗?在模型中,它将是以下代码..但我试图在Controller或View中执行此操作:VALID_EMAIL_REGEX=/\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/ivalidates:email,presence:true,format:{with:VALID_EMAIL_REGEX},

ruby-on-rails - 将项目插入mongoid数组

我有一个这样定义的模型:classFooinclude::Mongoid::Documentfield:name,type:Stringfield:followed_bars,type:Arrayfield:favorite_bars,type:Arrayend我像这样创建了一个Foo对象:foo=Foo.new(name:"Test")foo.save在我的数据库中,当我键入db.foo.find()时,我可以看到我刚刚创建的对象。然后,在我的应用程序中,我尝试这样做:foo=Foo.firstfoo.push(:followed_bars,"hello")每次我都会收到错误消息:A