按类型选择查询
表1
Code, desc, type id
01 Rajan 1
01 Sajan 1
01 Vijayan 2
01 Suresh 3
01 Caresh 4
01 Sujesh 4
01 vikran 4
02 desk 1
02 card 2
02 villa 2
02 megash 2
02 supan 3
....
我想按类型id查看表
预期输出
Code type-1 type-2 type-3 type-4
01 Rajan Vijayan suresh caresh
01 Sajan null null Sujan
01 null null null vikran
02 desk card supan null
02 null villa null null
02 null megash null null
如何针对上述条件进行查询
需要查询帮助
Table1
Code, desc, type id
01 Rajan 1
01 Sajan 1
01 Vijayan 2
01 Suresh 3
01 Caresh 4
01 Sujesh 4
01 vikran 4
02 desk 1
02 card 2
02 villa 2
02 megash 2
02 supan 3
....
I want to view the table by type id wise
Expected Output
Code type-1 type-2 type-3 type-4
01 Rajan Vijayan suresh caresh
01 Sajan null null Sujan
01 null null null vikran
02 desk card supan null
02 null villa null null
02 null megash null null
How to make a query for the above condition
Need Query Help
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
所以首先只是暂存你的数据。请注意,我将添加一个身份行 ID 以供稍后使用。
然后我们创建一个保留区域,使用该行 ID 来计算每个名称应该出现在代码的哪一行。
最后,我们在数据上创建一个 PIVOT 表(以“伪造”该运算符的标准 SQL 2000 方式完成)。然后,我们将该“PIVOT 表”放置在派生选择中,该选择仅返回我们想要的列,但允许我们对代码和 rownum 列进行排序以生成您要求的输出。
如果您需要对此进行进一步解释,请告诉我。
So first off just staging your data up. Note that I'm adding an identity row id for later.
Then we create a holding area that uses that row id to calculate which row of the code each of the names should go on.
Lastly, we create a PIVOT table on the data, (done in a standard SQL 2000 way of "faking" that operator). We then place that "PIVOT table" in a derived select that returns only the columns we want but allows us to sort on the code and rownum columns to generate the output you asked for.
Please let me know if you want further explanation on any of this.
尝试这个查询,它不会返回 null,但会返回重复的值,
如果您有任何疑问,请联系
Try this query it will not return null but will return repeated values
contact if you have any doubts