草庐IT

MySQL LIMIT 和 GROUP BY 与 JOIN

coder 2023-10-18 原文

有没有办法在一个查询中按一个表列进行 GROUP BY,但按另一个列进行 LIMIT。像这样的东西:

SELECT items.*, subitems.*
FROM items
LEFT OUTER JOIN subitems ON subitems.subitem_itemId = items.item_id
GROUP BY subitem.subitem_id
LIMIT 10

... 但是 LIMIT 10 适用于项目记录的数量,而不是实际的行。所以我得到 10 个项目,但子项目不受限制,因此可能超过 10 个实际行(或者如果 child 等于或少于 parent ,则不会)。

然后我可以在 php 中循环遍历这些并设置父/子关系。或者有更好的方法吗?

最佳答案

你必须为此使用子查询:

SELECT items.*,subitems.*
FROM (
    SELECT *
    FROM items
    LIMIT 10
) AS items
LEFT OUTER JOIN subitems ON subitems.subitem_itemId = items.item_id
GROUP BY subitem.subitem_id;

关于MySQL LIMIT 和 GROUP BY 与 JOIN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7156881/

有关MySQL LIMIT 和 GROUP BY 与 JOIN的更多相关文章

  1. ruby - 关于 Ruby 中 Dir[] 和 File.join() 的混淆 - 2

    我在Ruby中遇到了一个关于Dir[]和File.join()的简单程序,blobs_dir='/path/to/dir'Dir[File.join(blobs_dir,"**","*")].eachdo|file|FileUtils.rm_rf(file)ifFile.symlink?(file)我有两个困惑:首先,File.join(@blobs_dir,"**","*")中的第二个和第三个参数是什么意思?其次,Dir[]在Ruby中有什么用?我只知道它等价于Dir.glob(),但是,我对Dir.glob()确实不是很清楚。 最佳答案

  2. ruby - Dir[File.join(File.dirname(__FILE__), "subdirectory/**/*.rb")] 的较短版本? - 2

    这是一个有点微观的问题,但每次我创建一个gem并需要加载子目录下的所有文件以用于某种反射目的(或只是一个快速而肮脏的预加载)时,我问自己“肯定有更清洁的方法吗?”,引用这种常见模式:Dir[File.join(File.dirname(__FILE__),"subdirectory/**/*.rb")].each{|f|requiref}需要在__FILE__上调用File.dirname,这使得它不必要地冗长。你不能真正在gem中使用相对路径,因为你不知道你是从哪里加载的。 最佳答案 你用的是哪种ruby?在ruby​​1.9中,

  3. ruby-on-rails - 如何将 JOIN 信息添加到 rails seeds.rb 文件中? - 2

    我正在尝试构建一个seeds.rb文件以将初始管理员用户添加到数据库中。我有一个用户表和模型,以及一个角色表和模型。我有一个连接表,roles_users来加入用户角色和权限。这是架构:create_table"roles",:force=>truedo|t|t.string"name"t.datetime"created_at"t.datetime"updated_at"endcreate_table"roles_users",:id=>false,:force=>truedo|t|t.integer"role_id"t.integer"user_id"endcreate_table

  4. ruby-on-rails - Rails 4 Has_many :through join association with select - 2

    我正在尝试将Rails3.0应用程序升级到Rails4.0。我注意到的行为之一是模型之间的关系停止工作。假设我们有以下模型:classStudent:teacher_students,:select=>'teacher_students.met_with_parent,teachers.*'#TheRails4syntaxhas_many:teachers,->{select('teacher_students.met_with_parent,teachers.*')},:through=>:teacher_studentsendclassTeacher:teacher_student

  5. ruby - 不调用 Thread#join 可以吗? - 2

    可以不调用Thread#join吗?在这种情况下,我不关心线程是否爆炸-我只希望Unicorn继续处理。classMyMiddlewaredefinitialize(app)@app=appenddefcall(env)t=Thread.new{sleep1}t.join#isitokifIskipthis?@app.callenvendend我会得到“僵尸线程”或类似的东西吗? 最佳答案 不调用join完全没问题-事实上,多线程代码通常根本不需要join。如果您需要阻塞直到新线程完成,您应该只调用join。您不会得到“僵尸”线程。

  6. ruby - 如何修复 Ruby 中 join() 中的死锁 - 2

    我在Ruby中从事多线程工作。代码片段是:threads_array=Array.new(num_of_threads)1.upto(num_of_threads)do|i|Thread.abort_on_exception=truethreads_array[i-1]=Thread.new{catch(:exit)doprint"s#{i}"user_id=nilloopdouser_id=user_ids.pop()ifuser_id==nilprint"a#{i}"Thread.stop()enddosomething(user_id)endend}end#puts"aftert

  7. ruby-on-rails - 如何将参数传递给 LEFT JOIN? - 2

    **为更好理解而编辑****编辑重命名为文档**我想获取给定用户的所有带有投票记录的用户文档记录,如果该用户未对某些文档记录进行投票,我仍然希望获取所有没有投票的文档记录。例如:+------------+--------------+------+|document.par1|document.par2|vote|+------------+--------------+------+|2|z|y||3|w|NULL||4|x|NULL|+------------+--------------+------+如果我尝试在RubyonRails上:我。第一次尝试:Document.jo

  8. ruby - Python itertools 的 Ruby 等价物是什么,尤其是。组合/排列/groupby? - 2

    Python的itertools模块提供了很多关于使用生成器处理可迭代/迭代器的好东西。例如,permutations(range(3))-->012021102120201210combinations('ABCD',2)-->ABACADBCBDCD[list(g)fork,gingroupby('AAAABBBCCD')]-->AAAABBBCCDRuby中有哪些等价物?等效的,我的意思是快速和内存高效(Python的itertools模块是用C编写的)。 最佳答案 Array#permutation、Array#combin

  9. ruby-on-rails - Rails 3 Join——只选择某些列 - 2

    下面是评论和用户之间的关系。每个评论都有一个用户,所以我在下面的代码中构建了一个连接。我想知道如何构建此代码以仅在连接中包含特定列。我不需要所有的用户信息。只是名字。任何建议。当前代码:@comments=Comment.where(:study_id=>@study.id).joins(:user) 最佳答案 你可以使用这样的东西:@comments=Comment.joins(:user).select("comments.*,users.first_name").where(study_id:@study.id)

  10. ruby - 在 Ruby 中评估许多 bool 表达式,如 Array#join - 2

    在Ruby中,您可以使用Array#join使用可选的分隔符简单地将多个字符串连接在一起。["a","b","c"].join#=>"abc"["a","b","c"].join("-")#=>"a-b-c"我想知道是否有很好的语法糖可以用一堆bool表达式做类似的事情。例如,我需要将一堆表达式&&放在一起。但是,将使用哪些表达式由用户输入决定。所以与其做一堆cumulative_value&&=expression[:a]ifuser[:input][:a]我想先根据输入收集所有的表达式,然后&&一举将它们全部收集起来。像这样的东西:be1=x>ybe2=Proc.new{|stri

随机推荐