草庐IT

mysql中SQL语法

全部标签

sql - 如何获得不同的多态关联

我试图在没有任何重复的情况下显示多态关系列表。我有一个StoreViews表,其中包含一个名为viewable的多态字段(因此我的表中有一个viewable_id和viewable_type列)。现在我想显示View,每个多态关系只显示一次,没有重复。@views=StoreView..distinct(:viewable_id).distinct(:viewable_type).order("created_atDESC").limit(10)因此,如果StoreViews中有两条记录,并且都具有相同的可见关系,@views应该只返回最近的一条。然而,事实并非如此。

ruby - 语法是什么?在这个 Ruby 示例中是什么意思?

这个问题在这里已经有了答案:whatis"?"inruby(3个答案)关闭7年前。我正在学习Ruby,并在一些文档中找到了这段代码示例:require'find'total_size=0Find.find(ENV["HOME"])do|path|ifFileTest.directory?(path)ifFile.basename(path)[0]==?.Find.prune#Don'tlookanyfurtherintothisdirectory.elsenextendelsetotal_size+=FileTest.size(path)endend目的是总结树中所有文件的文件大小,不

ruby - 如何在 heroku 中使用自己的 mysql 数据库服务器?

我想使用托管在我自己服务器上的mysql数据库。我已经更改了DATABASE_URL和SHARED_DATABASE_URL配置变量以指向我的服务器,但它仍在尝试连接到heroku的amazonaws服务器。我该如何解决? 最佳答案 根据Herokudocumentation,更改DATABASE_URL是正确的方法。Ifyouwouldliketohaveyourrailsapplicationconnecttoanon-Herokuprovideddatabase,youcantakeadvantageofthissamemec

ruby-on-rails - Ruby 的 block 语法是如何工作的?

我是Ruby的新手,正在尝试理解这种语法:create_table:postsdo|t|t.string:titlet.string:contentt.string:likest.string:commentst.timestampsnull:falseend我完全理解什么这段代码在做什么,但我不明白它是如何工作的。更具体地说,我明白create_table是一个方法,:posts是一个参数,但我不明白其余的代码。 最佳答案 支持它:)create_table是一个方法。:posts是作为参数传递的符号。括号是可选的,所以它看起来很

ruby - 为什么 array.each 行为取决于 Array.new 语法?

我正在使用Ruby1.9.2-p290并发现:a=Array.new(2,[]).each{|i|i.push("a")}=>[["a","a"],["a","a"]]这不是我所期望的。但以下构造函数样式确实符合我的预期:b=Array.new(2){Array.new}.each{|i|i.push("b")}=>[["b"],["b"]]第一个例子是预期的行为吗?在ruby​​-doc中,我的size=2参数对于两个构造函数来说似乎是同一种参数。我认为,如果each方法通过了该参数,那么它将以相同的方式为两个构造函数使用它。 最佳答案

ruby-on-rails - 试图理解特定的 ruby​​ 语法

我是Ruby和Rails的新手,在浏览各种教程时,我偶尔会遇到一些我无法理解的Ruby语法。例如,这实际上是做什么的?rootto:"welcome#index"我猜想这可能是一个名为“root”的方法,但在那之后我就迷路了。“To”不是一个符号,是吗?冒号应该在前面,如果是的话,就像在":to"中一样。这是某种形式的使用哈希的关键字参数吗?在使用ruby​​1.9.3的irb中尝试时,我无法使此语法起作用。我知道这可能是一个RTFM问题,但我什至想不出要用谷歌搜索什么。谢谢!我还在研究这个语法,deffunc(h)putsh[:to]endx={:to=>"welcome#index

sql - 在 Rails 准备语句语法中使用 WHERE IN

假设我有一个id数组(从客户端接收):myArray=[1,5,19,27]我想返回该列表中(次要)id的所有项目。在SQL中这将是:SELECT*FROMItemsWHEREidIN(1,5,19,27)我知道我可以:Item.where(id:[1,5,9,27]),然而,将其添加到的查询使用准备语句语法的时间越长Item.where('myAttrib=?ANDmyOtherAttrib?ANDmyThirdAttrib=?',myVal[0],myVa[1],myVal[2])考虑到这一点,我想要的是:Item.where('idIN?',myArray)但是,这会产生语法错误

ruby - 如何设置mysql2时区选项以删除查询警告

使用mysql2做查询总是得到警告/usr/local/lib/ruby/gems/1.9.1/gems/mysql2-0.2.6/lib/active_record/connection_adapters/mysql2_adapter.rb:463:warning::database_timezoneoptionmustbe:utcor:local-defaultingto:local我确实看到了时区选项Mysql2现在支持两个时区选项::database_timezone-thisisthetimezoneMysql2willassumefieldsarealreadystored

ruby-on-rails - 将 Rails/ClearDB App 推送到 Heroku 错误 'Can' t 连接到 '127.0.0.1' 上的 MySQL 服务器

每次我跑:gitpushherokumaster我收到以下错误:Running:rakeassets:precompilerakeaborted!Can'tconnecttoMySQLserveron'127.0.0.1'我在运行rails-vRails3.2.11和ruby-vruby1.9.3p194(2012-04-20revision35410)[x86_64-darwin12.2.0]我已经通过HerokuCLI安装了ClearDB,它似乎工作正常,但我无法找出这个错误。这是我用于生产的yml:production:adapter:mysql2encoding:utf8hos

sql - 不同的加入 Rails

视频有很多事件我正在尝试获取所有在未来安排了事件的视频。我已经有了这个:named_scope:scheduled_in_future,:joins=>:event,:conditions=>["event.scheduled_start>?ANDevent.status=?",Time.now.to_i,'PENDING']这行得通,但如果同一个视频在未来有多个事件,它会给我重复的视频记录。当然,我可以遍历数组并清除重复项,但必须有一种SQL方法才能做到这一点。我尝试添加一个:select=>"DISTINCT(video.id)"但它只返回ID字段而不是整个记录。