- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试对一个月内的每一天运行查询。该月第一天的查询部分如下所示,并且有效:
CASE
WHEN CONCAT(
Shifts.d1a,
Shifts.d1b,
Shifts.d1c,
Shifts.d1d,
Shifts.d1e,
Shifts.d1f) = "" THEN "-"
ELSE
CONCAT (
IF (Shifts.d1a='Yes','A',''),
IF (Shifts.d1b='Yes','B',''),
IF (Shifts.d1c='Yes','C',''),
IF (Shifts.d1d='Yes','D',''),
IF (Shifts.d1e='Yes','E',''),
IF (Shifts.d1f='Yes','F','')
) END AS d1,
该月的第二天看起来是一样的,只是表引用的所有“d1”部分都将是“d2”,并且“END AS d1”将是“END AS d2”。
我继承了表结构;每个 d[n][x] 的值均为“Yes”或“”。不涉及空值。目标是在一天内获取单独字段的项目 - 即 d[n]a、d[n]b、d[n]c 等,并将它们连接成(例如)“ABF”,对于每个具有 yes 的字段值,如果所有字段均为空,则在 d[n] 列中生成一个连字符。
就像我说的,如果我运行 31 次几乎相同的代码,这就会起作用。我觉得这既丑陋又不必要。但我遇到了在 SELECT 中使用连接字符串作为列名称以及在输出中使用变量作为列别名的一部分的明显障碍。所以这不起作用:
BEGIN
DECLARE vcounter INT DEFAULT 0;
DECLARE vcolumn VARCHAR (10);
DECLARE vcolumna VARCHAR (64);
DECLARE vcolumnb VARCHAR (64);
DECLARE vcolumnc VARCHAR (64);
DECLARE vcolumnd VARCHAR (64);
DECLARE vcolumne VARCHAR (64);
DECLARE vcolumnf VARCHAR (64);
shift_loop: REPEAT
SET vcounter = vcounter + 1;
SET vcolumn = CONCAT ('d',vcounter);
SET vcolumna = CONCAT ('Shift.',vcolumn,'a');
SET vcolumnb = CONCAT ('Shift.',vcolumn,'b');
SET vcolumnc = CONCAT ('Shift.',vcolumn,'c');
SET vcolumnd = CONCAT ('Shift.',vcolumn,'d');
SET vcolumne = CONCAT ('Shift.',vcolumn,'e');
SET vcolumnf = CONCAT ('Shift.',vcolumn,'f');
SELECT
CASE
WHEN CONCAT(
vcolumna,
vcolumnb,
vcolumnc,
vcolumnd,
vcolumne,
vcolumnf) = '' THEN '-'
ELSE
CONCAT(
vcolumna,
vcolumnb,
vcolumnc,
vcolumnd,
vcolumne,
vcolumnf
)
END
AS vcolumn;
UNTIL vcounter = 1
END REPEAT;
END
是的,我知道过程中的 CASE 语句是不必要的——我可以将最终 CONCAT 的结果分配给一个变量并针对空值对其进行测试。我只是保持原样,以便更好地了解我想要做什么。
结果是,对于每一行,我都会得到一个名为“vcounter”的列,其内容为“Shift.d1aShift.d1bShift.d1c
”等。有人有什么建议吗?
编辑添加
好的,谢谢,我查看了建议的答案,但我不知道如何使其与我需要的 WHILE 语句一起使用。这是我将代码更改为:
BEGIN
SET @vcounter = 0;
SET @vcounter = @vcounter + 1;
SET @vtable = 'Table_X';
SET @vcolumn = CONCAT ('d',@vcounter);
SET @vcolumna = CONCAT (@vtable,'.',@vcolumn,'a');
SET @vcolumnb = CONCAT (@vtable,'.',@vcolumn,'b');
SET @vcolumnc = CONCAT (@vtable,'.',@vcolumn,'c');
SET @vcolumnd = CONCAT (@vtable,'.',@vcolumn,'d');
SET @vcolumne = CONCAT (@vtable,'.',@vcolumn,'e');
SET @vcolumnf = CONCAT (@vtable,'.',@vcolumn,'f');
SET @vshifts = CONCAT
(@vcolumna,',',@vcolumnb,',',@vcolumnc,',',@vcolumnd,',',@vcolumne,',',@vcolumnf);
SET @vquery = CONCAT ('SELECT CASE WHEN CONCAT (',
@vshifts,
') ="" THEN "-" ELSE
CONCAT (IF(',@vcolumna,' = "Yes","A",""),
IF(',@vcolumnb,' = "Yes","B",""),
IF(',@vcolumnc,' = "Yes","C",""),
IF(',@vcolumnd,' = "Yes","D",""),
IF(',@vcolumne,' = "Yes","E",""),
IF(',@vcolumnf,' = "Yes","F","")
)END AS ',@vcolumn,' FROM ',@vtable);
PREPARE stmt FROM @vquery;
EXECUTE stmt;
END
这对于一天来说效果很好。问题是,在任何插入 WHILE 或 REPEAT 语句的地方,都会得到不好的结果。我发现的最接近的结果最终会产生如下所示的结果
d1
D
F
A
B
d2
A
AB
C
-
等等。我想要的是
d1 d2
D A
F AB
A C
B -
我显然不太了解我在这里做什么,所以我真的很感谢任何人可以提供的帮助。谢谢。
最佳答案
好的,我自己解决了。这是有效的:
BEGIN
SET @vcounter = 0;
SET @vtable = 'tablename';
SET @vquery = 'SELECT
last_name As Last_Name,
first_name As First_Name, ';
shift_loop: REPEAT
SET @vcounter = @vcounter + 1;
SET @vcolumn = CONCAT ('d',@vcounter);
SET @vcolumna = CONCAT (@vcolumn,'a');
SET @vcolumnd = CONCAT (@vcolumn,'b');
SET @vcolumnp = CONCAT (@vcolumn,'c');
SET @vcolumne = CONCAT (@vcolumn,'d');
SET @vcolumnt = CONCAT (@vcolumn,'e');
SET @vcolumns = CONCAT (@vcolumn,'f');
SET @vshifts = CONCAT (@vcolumna,',',@vcolumnb,',',@vcolumnc,',',@vcolumnd,',',@vcolumne,',',@vcolumnf);
SET @vquery = CONCAT (@vquery,' CASE WHEN CONCAT (',
@vshifts,
') ="" THEN "-" ELSE
CONCAT (IF(',@vcolumna,' = "Yes","A",""),
IF(',@vcolumnb,' = "Yes","B",""),
IF(',@vcolumnc,' = "Yes","C",""),
IF(',@vcolumnd,' = "Yes","D",""),
IF(',@vcolumne,' = "Yes","E",""),
IF(',@vcolumnf,' = "Yes","F","")
) END AS ',@vcolumn,',');
Until @vcounter = 31
END REPEAT;
SET @vquery = CONCAT (
@vquery,'
comment AS Comment,
_submitted_ AS Submitted
FROM ',@vtable);
PREPARE stmt FROM @vquery;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END
关于mysql - CONCATS 用于列名、列别名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41715921/
数据库设置: http://sqlfiddle.com/#!2/4d1c2/1 以下查询选择属于productID的所有标签及其位置,逗号分隔: SELECT CONCAT_WS(',', GROUP
要连接两个文件,它看起来像这样: concat: { src: ['common.js','js/app.js'], dest: 'assets/js/app.js' } 如果
我有一个执行 SQL 脚本的 PDI(Kettle)转换,脚本的输出是一列,如下所示: val1 val2 val3 val4 "more values"... 我需要像这样在一个 Excel 单元格
我正在尝试传递一个参数 [例如@X nvarchar(MAX)] 转换成变量 [例如@message nvarchar(MAX)] 在存储过程中。该变量使用 CONCAT 组合字符串值和变量,它最终成
我不知道如何解释我的问题... 这是我的sql请求: SELECT DISTINCT CONCAT (nompropre, ' ', Auteur, ' de ', localite) AS aute
如何在与另一个表连接的表中使用 concat 和 group concat。架构如下所示: 第一表: MariaDB [ittresnamuda]> select * from tb_tipe_req
在我的 CREATE VIEW 中,我想: SELECT CONCAT( t.str1, t.str2 ) AS Title, CHAR_LENGTH( Title ) AS Length 但这会产生
我正在使用 CriteriaBuilder.concat 连接 2 个字符串,代码如下: Expression concat = criteriaBuilder.concat(expr1, expr2
我有以下继承 IEnumerable 的类 public class LinesEnumerable : IEnumerable { protected readonly IPointSeri
_.concat 和有什么区别lodash 和 Array.prototype.concat() ?. 最佳答案 欢迎来到 Stackoverflow! 这些函数的工作方式相同,但语法不同: _.co
我有一个非常大的表(几百万条记录)。表中的列 A 目前是这样的:id、道路名称、纬度、经度,其中 id 是自动增量 PK。 目前,1 个道路名称可以在表中包含多个条目,因为每条道路都映射到多个(纬度、
我测试了各种数组连接技术,并不是因为它实际上对我的代码很重要,而只是顺便说一句,看看我们现在在哪里。正如预期的那样,非常新的 ES 2015 传播运算符在 JavaScript 数组上被旧的 conc
我有一个数组,我需要使用一些编辑重新编译。我是在 async.concat() 的帮助下完成的,但有些东西不起作用。告诉我,哪里错了? async.concat(dialogs, function(d
在 JavaScript 中,我遇到过以两种主要方式编写的代码,用于连接两个(或更多)使用 .concat() 的数组。 Array 上的方法目的。 (假设在下文中,arr1 和 arr2 是作为 .
我之前曾使用 stack over flow 来解决我的 sql 问题并且成功了。 这一次我的下一期可能不会那么成功。 我有一个名为 Statements_1 的表,该表大约有 50 列,假设有 10
我在想以一种相当奇怪的方式从数据库获取东西时遇到了一些麻烦。假设我有下一张 table ID | Rating 229 | 3 229 | 2 229 | 4 229 | 2 2
我有类似表中的内容 mysql> select uuid , short-uuid FROM sampleUUID WHERE identifier ="test123"; +------------
我有一个查询,用于获取我离开加入两个表的帖子: 类别和标签:LEFT JOIN 到链接表→‖INNER JOIN 到类别和标签名称表。 LEFT JOIN wp_term_relationships
我目前正在开发一个大型 angular.js 项目。我使用 grunt 将所有文件合并/丑化为一个大的 target.js 文件,然后将其包含在索引页中。 我已经意识到,这使得在开发环境中调试变得非常
我的表中有三列:firstName、lastName 和 jobTitle。我想将 firstName 和 lastName 连接为 Fullname,然后连接 Fullname 和 jobTitle
我是一名优秀的程序员,十分优秀!