- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我创建了下面的 SQL 脚本,它创建了四个表并将数据插入表中以演示我的问题(我希望这有帮助!)。
出现这个问题是因为最初这些数据存储在一个包含 400 列的表中,它变得非常难以管理,所以我想找到一种更好的方法来存储参数:
use master
GO
create database sptest
go
use sptest
go
CREATE TABLE JobFiles (
[Id] int PRIMARY KEY IDENTITY(0,1),
[JobName] nvarchar(256) DEFAULT '',
[CreateDate] DateTime NOT NULL DEFAULT GETDATE(),
[ModifyDate] DateTime NOT NULL DEFAULT GETDATE(),
[CreatedByUser] nvarchar(64) DEFAULT '',
[ModifiedByUser] nvarchar(64) DEFAULT '')
GO
CREATE TABLE jpChar (
[jpId] int PRIMARY KEY IDENTITY(0,1),
[JobId] int REFERENCES JobFiles(Id),
[jpName] varchar(64),
[jpValue] nvarchar(255))
CREATE TABLE jpInt (
[jpId] int PRIMARY KEY IDENTITY(0,1),
[JobId] int REFERENCES JobFiles(Id),
[jpName] varchar(64),
[jpValue] int)
CREATE TABLE jpText (
[jpId] int PRIMARY KEY IDENTITY(0,1),
[JobId] int REFERENCES JobFiles(Id),
[jpName] varchar(64),
[jpValue] Text)
use spTest
go
INSERT INTO JobFiles(JobName) VALUES ('File0')
INSERT INTO JobFiles(JobName) VALUES ('File1')
INSERT INTO JobFiles(JobName) VALUES ('File2')
INSERT INTO jpChar(JobId,jpName, jpValue) VALUES (0, 'User', 'Paul')
INSERT INTO jpChar(JobId,jpName, jpValue) VALUES (0, 'Dept', 'IT')
INSERT INTO jpInt (JobId,jpName, jpValue) VALUES (0, 'Hours', '40')
INSERT INTO jpText (JobId,jpName, jpValue) VALUES (0, 'Notes', 'Some Text')
INSERT INTO jpChar(JobId,jpName, jpValue) VALUES (1, 'User', 'Bob')
INSERT INTO jpChar(JobId,jpName, jpValue) VALUES (1, 'Dept', 'Sales')
INSERT INTO jpInt (JobId,jpName, jpValue) VALUES (1, 'Hours', '20')
INSERT INTO jpText (JobId,jpName, jpValue) VALUES (1, 'Notes', 'Some more Text')
INSERT INTO jpChar(JobId,jpName, jpValue) VALUES (2, 'User', 'Jane')
INSERT INTO jpChar(JobId,jpName, jpValue) VALUES (2, 'Dept', 'Support')
SELECT JobFiles.Id, JobFiles.JobName,
jpChar.jpName AS cName, jpChar.jpValue AS cValue,
jpInt.jpName AS iName, jpInt.jpValue AS iValue,
jpText.jpName AS txtName, jpText.jpValue AS txtValue
FROM JobFiles INNER JOIN
jpChar ON JobFiles.Id = jpChar.JobId LEFT JOIN
jpInt ON JobFiles.Id = jpInt.JobId LEFT JOIN
jpText ON JobFiles.Id = jpText.JobId
每个表中有数百个参数(以上只是少数),它们都引用了 JobFiles 表中的一行。
当我运行上面的 SELECT 语句时,我得到了预期的以下结果:
id JobName cName cValue iName iValue txtName txtValue
0 File0 User Paul Hours 40 Notes Some Text
0 File0 Dept IT Hours 40 Notes Some Text
1 File1 User Bob Hours 20 Notes Some more Text
1 File1 Dept Sales Hours 20 Notes Some more Text
2 File2 User Jane NULL NULL NULL NULL
2 File2 Dept Support NULL NULL NULL NULL
我想要实现的是以不同方式排列数据以匹配原始 400 列表的外观:
将名为cName、iName、txtName的列的数据值返回到Columns中。将名为cValue、iValue、txtValue的列的数据值返回到行数据中。
即
id JobName User Dept Hours Notes
0 File0 Paul IT 40 Some Text
1 File1 Bob Sales 20 Some more Text
2 File2 Jane Support NULL NULL
. . . . . .
我不确定我将如何着手做这件事,希望得到任何建议和帮助?我还有其他问题,我将单独发布。
先谢谢你。
最佳答案
我可能会将“部门”记录分解到它们自己的表中,并相应地更改您的查询。
您遇到的麻烦是因为在您当前的数据库结构中,'User'/'Bob' 和 'Dept'/'IT' 之间没有区别
关于SQL 语法 : Create a single table with column names created from data stored over multiple tables,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1755562/
这个问题在这里已经有了答案: What is the best way to parse html in C#? [closed] (15 个答案) 关闭 3 年前。 string input =
为什么 wrapper #4 没有继承其父表容器的高度?表格嵌套在一个显示 block 包装器中,每个嵌套的div是显示表格,每个表格继承到最里面的一个。是什么原因造成的,我该如何解决? jsfidd
我正在使用带有 Bootstrap 的自定义 css 作为外边框。但顶部边框不可见,除非我将其大小设置为 2 px。 我该如何解决这个问题? HTML #name 1.one 2.two 3.thr
我正在逻辑层面上设计一个数据库,以便稍后将其传递给程序员来交付。我只是粗略地了解它们的工作原理,所以我很难简洁地表达我的问题。这是我的问题: 我有一个名为 MEANINGS 的表。 我有一个名为 WO
在 Laravel 上,我们可以使用 DB::table('table')->get(); 或使用 model::('table')->all() 进行访问;我的问题是它们之间有什么区别? 谢谢。 最
我试图从以下内容中抓取 URL从 WorldOMeter 获取 CoVid 数据,在此页面上存在一个表,id 为:main_table_countries_today其中包含我希望收集的 15x225
这是我的图表数据库:/image/CGAwh.png 我用 SEQUELIZE 制作了我的数据库模型: 型号:级别 module.exports = (sequelize, DataTypes) =>
我真的不明白为什么我的代码不能按预期工作。当我将鼠标悬停在表格的每一行上时,我想显示一个图像(来 self 之前加载的 JSON)。每个图像根据行的不同而不同,我想将它们显示在表格之外的另一个元素中。
假设我的数据库中有一张地铁 map ,其中每条线路的每个站点都是一行。如果我想知道我的线路在哪里互连: mysql> SELECT LineA.stop_id FROM LineA, LineB WH
我最近经常使用这些属性,尤其是 display: table-cell。它在现代浏览器中得到了很好的支持,并且它对某些网格有很多好处,并且可以非常轻松地对齐内容,而无需棘手的标记。但在过去的几天里,我
在 CSS 中,我可以这样做: http://s1.ipicture.ru/uploads/20120612/Uk1Z8iZ1.png http://s1.ipicture.ru/uploads/20
问题作为标题,我正在学习sparkSQL,但我无法很好地理解它们之间的区别。谢谢。 最佳答案 spark.table之间没有区别& spark.read.table功能。 内部 spark.read.
我正在尝试根据 this answer 删除表上的非空约束.但是,它似乎没有在 sqlite_sequence 中创建条目。这样做之后,即使我可以在使用测试表时让它正常工作。 有趣的是,如果我备份我的
var otable = new sap.m.Table();//here table is created //here multiple header I'm trying to create t
下面两种方法有什么区别: 内存 性能 答: select table.id from table B: select a.id from table a 谢谢(抱歉,如果我的问题重复)。 最佳答案 完
我尝试在表格后添加点,方法是使用 table::after 选择器创建一个点元素并使用 margin: 5px auto 5px auto; 将其居中。它有效,但似乎在第一个表格列之后添加了点,而不是
我正在设计一个可以标记任何内容的数据库,我可能希望能够选择带有特定标记的所有内容。 我正在为以下两个选项而苦苦挣扎,希望得到一些建议。如果有更好的方法请告诉我。 选项A 多个“多对多”连接表。 tag
"center" div 中的下表元素导致 "left" div 中的内容从顶部偏移几个像素(在我的浏览器中为 8 ).在表格之前添加一些文本可消除此偏移量。 为什么?如何在不要求在我的表格前添加“虚
我是一名优秀的程序员,十分优秀!