- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在this fiddle我有一个名为“标签”的表。它有四列:
id counter sessionid tag
(1, 1, 'session1', 'start'),
(2, 2, 'session1', 'sessionname1'),
(3, 3, 'session1', 'unimportant tag'),
(4, 4, 'session1', 'unimportant tag'),
(5, 5, 'session1', 'end'),
(6, 1, 'session2', 'start'),
(7, 2, 'session2', 'sessionname2'),
(8, 3, 'session2', 'end')
我想显示此表的所有列PLUS一个名为“name”的additional行。此列中的数据是根据以下条件生成的:
名称写在每个 sessionid 的第二行。这实际上意味着我检查哪一行有标签“开始”。然后将 session 的名称写入列标记,其中 counter 比标记为“start”的行1 高。
我尝试了第一个查询,该查询适用于第一个 sessionid,但随后在第二个 sessionid 处失败,因为它在每一行中写入“sessionname1”。 正确的 查询将为 ID 为 6、7、8 的行返回 name = "sessionname2"。
SELECT t1.*,
(SELECT top 1 t2.tag
FROM tags t2
JOIN ( SELECT * FROM tags WHERE tag = 'start' ) t3
ON (t2.counter = t3.counter + 1) AND t3.sessionid = t2.sessionid
) AS name
FROM tags t1
我必须更改什么才能在每一行中获得正确的名称?
查看我的 SQL Fiddle
当然,预期的输出显示ALL 行。它看起来像下面这样:
id counter sessionid tag name
(1, 1, 'session1', 'start', 'sessionname1'),
(2, 2, 'session1', 'sessionname1', 'sessionname1'),
(3, 3, 'session1', 'unimportant tag','sessionname1'),
(4, 4, 'session1', 'unimportant tag','sessionname1'),
(5, 5, 'session1', 'end', 'sessionname1'),
(6, 1, 'session2', 'start', 'sessionname2'),
(7, 2, 'session2', 'sessionname2', 'sessionname2'),
(8, 3, 'session2', 'end', 'sessionname2')
重要提示:
重要的是,trackingcounter 列比带有“start”的行大 1。每次 2 都是NOT,也有可能“开始”的行有 trackingcounter = 80,然后 trackingcounter 必须是 81。
最佳答案
像下面这样的东西应该适合你:
SELECT tags.*, tagnames.tag AS sessionname
FROM tags
INNER JOIN
(SELECT sessionid, tag
FROM tags WHERE counter = 2) AS tagnames
ON tags.sessionid = tagnames.sessionid
此方法的工作原理是创建一个仅包含 session 标识符和名称(这是 INNER JOIN 子查询)的表,然后我们将其连接回主集以允许我们将 session 名称作为不同的专栏。
它有两个假设:
INNER JOIN
指定我们始终希望 session 有一个名称counter = 2
编辑:
根据您的评论,我发现我们无法通过 counter = 2
来识别名称行,但对于给定的 sessionid,它始终是 second
行。因此,我们可以执行以下操作来选择每个 sessionid 的第二行:
SELECT @previous_session := null;
SELECT
sessionid,
counter,
tag,
@counter_rank := IF(@previous_session = sessionid, @counter_rank + 1, 1) AS counter_rank,
@previous_session := sessionid
FROM tags
ORDER BY sessionid, counter ASC
这会使用 user defined variable 生成一个“人工”行号每个 session 组,因此我们始终可以找到按 session ID 和计数器排序的第二条记录。
将其合并到第一个查询中可以得到:
SELECT @previous_session := null;
SELECT tags.*, tagnames.tag AS sessionname
FROM tags
INNER JOIN
(SELECT countranks.sessionid, countranks.tag
FROM (
SELECT
sessionid,
counter,
tag,
@counter_rank := IF(@previous_session = sessionid, @counter_rank + 1, 1) AS counter_rank,
@previous_session := sessionid
FROM tags
ORDER BY sessionid, counter ASC
) AS countranks WHERE countranks.counter_rank = 2
) AS tagnames
ON tags.sessionid = tagnames.sessionid;
关于mysql - SQL SELECT 从具有特殊条件的同一表生成附加列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23336175/
我以一种特殊的方式收到以下错误。 The point at which the driver is attempting to click on the element was not scrolle
我有一些包含如下方法的编译库: public boolean foo(String userID) { Class ntSystemClass = Thread.currentThread()
假设我有下表 name | genre --------------------- book 1 | scifi book 2 | horror book 3
我正在用代码进行语言翻译。 self.title.text = [NSString stringWithFormat:NSLocalizedString(@"Q%ld", nil), (long)qu
我想这样做,但到目前为止,我所拥有的只是: print("Will you go out with me?") 我希望代码能够正常工作,以便人们可以回答“是/否”,如果回答是"is",则将返回一条消息
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: How can I decode html characters in c#? 我有来自 HTML 的字符,
我想在 JavaScript 中对以下形式的字符串执行 ucwords(),它应该返回 Test1_Test2_Test3。 我已经在 SO 上找到了一个 ucwords 函数,但它只需要空格作为新词
“任何长度的正数表示为数字字符数组,因此介于‘0’和‘9’之间。我们知道最重要的密码位于数组索引 0 的位置。 例子: - 号码是 10282 - 数组将是数字 = [1,0,2,8,2] 考虑到这一
我目前正在开发一个显示特殊 unicode 字符(例如 ꁴ)的应用 现在我遇到了在旧设备上无法显示这些符号的问题。我如何知道它是否适用于当前设备? 我是否必须为每个 SDK 版本创建一个虚拟 Andr
在 HTML、XML 和部分 DTD 中,有两种特殊的标记结构: 以感叹号开头的标签结束,例如 和 以问号开头的标签 ,例如 和 我的问题是,这些构造类型中的每一种是否都有不同的名称,或者我是否必
我目前正在用 python 构建一个 shell。shell 可以执行 python 文件,但我还需要添加使用 PIPE 的选项(例如“|”表示第一个命令的输出将是第二个命令的输入)。 为了做到这一点
我的 MVC 项目中的路由无法正常工作... 我希望我所有的 View 都在 Views > Shared 文件夹中,如下所示: Error.cshtml (default) Index.cshtml
我有一个函数: public static ImageIcon GetIconImageFromResource(String path){ URL url = ARMMain.class.g
好的,所以我想在我的 html 页面中包含下面的字符。看起来很简单,只是我找不到它们的 HTML 编码。 注意:我想在没有大小元素的情况下执行此操作,纯文本就可以了 ^_^。 干杯。 最佳答案 你可以
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 3 年前。
我是 C# 的新手,正在尝试使用 ASP.Net GridView(框架 3.5),当 gridView 文本包含以下内容时,我发现了一个大问题: ñ/Ñ/á/Á/é/É/í/Í/ó/Ó/ú/Ú or
在 Java 中,我尝试编写一个正则表达式来匹配特殊类型的 HTTP URL: http:///# 所以字符串有 4 段: 字符串文字:“http://”;那么 任意 1 个以上字符的字符串;那么 字
当我写查询时,我在表中有“to”列 SELECT to FROM mytable mysql_error 返回错误,如果将单词to插入``引号,即 SELECT `to` FROM mytable 查
我遇到了一个问题。事实上,我使用越南语文本,我想找到每个包含大写字母(大写字母)的单词。当我使用“re”模块时,我的函数 (temp) 没有捕捉到像“Đà”这样的词。另一种方法 (temp2) 是一次
在我的文本中,我想用一个空格替换以下特殊字符: symbols = ["`", "~", "!", "@", "#", "$", "%", "^", "&", "*", "(", ")", "_",
我是一名优秀的程序员,十分优秀!