我有 3 个表,其中包含以下数据:
第一个表称为连接,其中 connections.username1 是跟随者,connections.username2 是被跟随者。
它有以下几行:
connections.username1 | connections.username2
mikha | guy
guy | maricela
maricela | guy
第二个表称为问题。它有一列用于提问者,名为 questions.asker_username,另一列用于接收问题的人,名为 questions.target_username。当提问者称为“sys.tem”而目标称为“every.one”时,它被认为是一个全局问题,可以由所有成员回答。
匿名用户可以询问,他们的 ip 被记录为 asker_username。
它有以下几行:
questions.id | questions.asker_username | questions.target_username | questions.question
1 | mikha | guy | what's your name?
2 | mikha | maricela | What's your age?
3 | guy | mikha | what's your name?
4 | maricela | guy | favorite food?
5 | xx.xx.xxx.xx | mikha | favorite pet?
6 | xx.xx.xxx.xx | guy | first name?
7 | xx.xx.xxx.xx | maricela | first name?
8 | sys.tem | every.one | what's ur name?
9 | sys.tem | every.one | favorite movie?
10 | sys.tem | every.one | favorite game?
第三个表称为答案。 answers 表中的 id 与问题 id 相同。该表有一列用于 ID 和用户名以及答案。
answers.id | answers.username | answers.answer
1 | guy | my name is guy
2 | maricela | my name is maricela
3 | mikha | my name is mikha
4 | guy | pizza
8 | guy | guy is my name
8 | maricela | maricela is my name
9 | maricela | avatar
我想要一个结合以下与“mikha”和他关注的人相关的条件的查询:
1) questions.asker_username 不是“mikha”
2) questions.target_username 是“mikha”或他关注的任何用户。
3) 如果 questions.target_username 等于“every.one”并且由“mikha”回答,则显示问题。
4) 如果questions.target_username 等于“every.one”并且由“mikha”关注的任何人回答,则显示问题及其答案。如果“mikha”关注的用户没有回答,则不显示该问题。
5) 如果 questions.target_username 等于“every.one”并且根本没有人回答,则显示一次问题。
6) 如果 questions.target_username 等于“every.one”并且“mikha”没有回答,也没有他关注的任何人回答,则只显示一次问题。
我使用以下查询:
SELECT questions.id,answers.id,questions.asker_username,questions.target_username,
answers.username,questions.question,answers.answer
FROM questions
LEFT JOIN answers ON (questions.id = answers.id)
LEFT JOIN connections ON connections.username1 = 'mikha'
AND (questions.target_username = connections.username2
OR questions.asker_username = connections.username2
OR connections.username2 = answers.username)
WHERE questions.asker_username <> 'mikha'
AND (questions.target_username = 'mikha'
OR questions.target_username = connections.username2
OR (questions.target_username = 'every.one'
AND (answers.username = 'mikha'
OR answers.username = connections.username2
OR answers.username IS NULL)
)
)
GROUP BY questions.id,answers.username
我期望的结果:
questions.id | answers.id | questions.asker_username | questions.target_username | answers.username | questions.question | answers.answer
3 | 3 | guy | mikha | mikha | what's your name? | my name is mikha
4 | 4 | maricela | guy | guy | favorite food? | pizza
5 | 5 | xx.xx.xxx.xx | mikha | NULL | favorite pet? | NULL
6 | 6 | xx.xx.xxx.xx | guy | NULL | first name? | NULL
8 | 8 | sys.tem | every.one | NULL | what's ur name? | NULL
8 | 8 | sys.tem | every.one | guy | what's ur name? | guy is my name
9 | 9 | sys.tem | every.one | NULL | favorite movie? | NULL
10 | 10 | sys.tem | every.one | NULL | favorite game? | NULL
我实际得到的结果:
questions.id | answers.id | questions.asker_username | questions.target_username | answers.username | questions.question | answers.answer
3 | 3 | guy | mikha | mikha | what's your name? | my name is mikha
4 | 4 | maricela | guy | guy | favorite food? | pizza
5 | 5 | xx.xx.xxx.xx | mikha | NULL | favorite pet? | NULL
6 | 6 | xx.xx.xxx.xx | guy | NULL | first name? | NULL
8 | 8 | sys.tem | every.one | guy | what's ur name? | guy is my name
10 | 10 | sys.tem | every.one | NULL | favorite game? | NULL
我在 http://sqlfiddle.com/#!2/29929e/1 上构建了一个方案向您展示我实际得到的结果
谢谢:)
最佳答案
好的,让我们从最简单的开始(您的第一条规则):
SELECT q.id, a.id, q.asker_username, q.target_username, a.username, q.question, a.answer
FROM questions q
LEFT JOIN answers a ON q.id = a.id
WHERE q.asker_username <> 'mikha'
GROUP BY q.id,a.username
现在让我们添加您的第二条规则 - 现在添加了更多的复杂性...
SELECT q.id, a.id, q.asker_username, q.target_username, a.username, q.question, a.answer
FROM questions q
LEFT JOIN answers a ON q.id = a.id
WHERE q.asker_username <> 'mikha'
AND q.target_username = 'mikha'
OR q.target_username IN (
SELECT username2
FROM connections
WHERE username1 = 'mikha'
)
GROUP BY q.id,a.username
现在是第三条规则(mikha 回答的每个人):
SELECT q.id, a.id, q.asker_username, q.target_username, a.username, q.question, a.answer
FROM questions q
LEFT JOIN answers a ON q.id = a.id
WHERE q.asker_username <> 'mikha'
AND q.target_username = 'mikha'
OR q.target_username IN (
SELECT username2
FROM connections
WHERE username1 = 'mikha'
)
OR (q.target_username = 'every.one' AND a.username = 'mikha')
GROUP BY q.id,a.username
现在是第四条规则:
SELECT q.id, a.id, q.asker_username, q.target_username, a.username, q.question, a.answer
FROM questions q
LEFT JOIN answers a ON q.id = a.id
WHERE q.asker_username <> 'mikha'
AND q.target_username = 'mikha'
OR q.target_username IN (
SELECT username2
FROM connections
WHERE username1 = 'mikha'
)
OR (q.target_username = 'every.one' AND a.username = 'mikha')
OR (q.target_username = 'every.one' AND a.username IN (
SELECT username2
FROM connections
INNER JOIN answers ON answers.username = connections.username2
AND answers.answers IS NOT NULL
WHERE username1 = 'mikha'
))
GROUP BY q.id,a.username
第五条规则(耶稣!):
SELECT q.id, a.id, q.asker_username, q.target_username, a.username, q.question, a.answer
FROM questions q
LEFT JOIN answers a ON q.id = a.id
WHERE q.asker_username <> 'mikha'
AND q.target_username = 'mikha'
OR q.target_username IN (
SELECT username2
FROM connections
WHERE username1 = 'mikha'
)
OR (q.target_username = 'every.one' AND a.username = 'mikha')
OR (q.target_username = 'every.one' AND a.username IN (
SELECT username2
FROM connections
INNER JOIN answers ON answers.username = connections.username2
AND answers.answers IS NOT NULL
WHERE username1 = 'mikha'
))
OR (q.target_username = 'every.one' AND a.answer IS NULL)
GROUP BY q.id,a.username
最后一个:
SELECT q.id, a.id, q.asker_username, q.target_username, a.username, q.question, a.answer
FROM questions q
LEFT JOIN answers a ON q.id = a.id
WHERE q.asker_username <> 'mikha'
AND q.target_username = 'mikha'
OR q.target_username IN (
SELECT username2
FROM connections
WHERE username1 = 'mikha'
)
OR (q.target_username = 'every.one' AND a.username = 'mikha')
OR (q.target_username = 'every.one' AND a.username IN (
SELECT username2
FROM connections
INNER JOIN answers ON answers.username = connections.username2
AND answers.answers IS NOT NULL
WHERE username1 = 'mikha'
))
OR (q.target_username = 'every.one' AND a.answer IS NULL)
OR (q.target_username = 'every.one' AND a.username NOT IN (
SELECT username2
FROM connections
INNER JOIN answers ON answers.username = connections.username2
AND answers.answers IS NOT NULL
WHERE username1 = 'mikha'
))
GROUP BY q.id,a.username
我认为规则 4 和规则 6 有点相互矛盾(可以说是矛盾的),当在一个查询中使用时,它的效果与省略时相同......
我没有测试任何查询,但我相信它们有效。
关于php - MYSQL错误结果输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13878674/
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我正在使用puppet为ruby程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这
这是一道面试题,我没有答对,但还是很好奇怎么解。你有N个人的大家庭,分别是1,2,3,...,N岁。你想给你的大家庭拍张照片。所有的家庭成员都排成一排。“我是家里的friend,建议家庭成员安排如下:”1岁的家庭成员坐在这一排的最左边。每两个坐在一起的家庭成员的年龄相差不得超过2岁。输入:整数N,1≤N≤55。输出:摄影师可以拍摄的照片数量。示例->输入:4,输出:4符合条件的数组:[1,2,3,4][1,2,4,3][1,3,2,4][1,3,4,2]另一个例子:输入:5输出:6符合条件的数组:[1,2,3,4,5][1,2,3,5,4][1,2,4,3,5][1,2,4,5,3][
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我克隆了一个rails仓库,我现在正尝试捆绑安装背景:OSXElCapitanruby2.2.3p173(2015-08-18修订版51636)[x86_64-darwin15]rails-v在您的Gemfile中列出的或native可用的任何gem源中找不到gem'pg(>=0)ruby'。运行bundleinstall以安装缺少的gem。bundleinstallFetchinggemmetadatafromhttps://rubygems.org/............Fetchingversionmetadatafromhttps://rubygems.org/...Fe
在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee
我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie