大佬教程收集整理的这篇文章主要介绍了插入来自其他函数的自定义格式和值的行,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在为一所虚构的学校创建一个数据库。我有一个表 Courses (PK Coursecode nvarchar(50),Credits int,FK Teacher nvarchar(50),name nvarchar(50))
、另一个 Teachers
和另一个名为 CourseTeachers
的表,引用这两个表并存储有关工作时间的数据。
我想要完成的是创建一个以年份为参数并以格式返回表格的函数
FirsT name | LAST name | course1/period | course2/period | course3/period | course4/period
teacher1 fn | teacher1 ln | hrs worked course1 | ...
请注意,最上面一行是表格中的数据,而不是属性。
为此,我创建了一个函数 getFourCoursesByYear
,它只是执行以下操作
SELECT top 4 CourseTeachers.Course,CourseTeachers.Teacher
FROM CourseTeachers
WHERE CourseTeachers.year = @year
我遇到的问题:
到目前为止我考虑的解决方案涉及子查询,并且类似于
DECLARE @table table
(
Firstname nvarchar(50),Lastname nvarchar(50),c1 nvarchar(50),c2 nvarchar(50),c3 nvarchar(50),c4 nvarchar(50)
);
INSERT INTO @table
VALUES('First name','Last name',(SELECT Course FROM getFourCoursesByYear(@year)),...)
但是,如您所见,代码不完整且无法运行。
您查询的正确语法等于以下代码
DECLARE @table TABLE
(
Firstname nvarchar(50),Lastname nvarchar(50),c1 nvarchar(50),c2 nvarchar(50),c3 nvarchar(50),c4 nvarchar(50)
);
Declare @FirstName nvarchar(100) = 'First Name'
Declare @LastName nvarchar(100) = 'Last Name'
INSERT INTO @table(FirstName,Lastname,c1)
SELECT @FirstName,@LastName,Course
FROM getFourCoursesByYear(@year)
,
您可以对行号进行透视。您希望按什么顺序排列行号取决于您。
DECLARE @year int;
SELECT
CoursePeriod1 = MAX(CASE WHEN rn = 1 THEN CoursePeriod END),CoursePeriod2 = MAX(CASE WHEN rn = 2 THEN CoursePeriod END),CoursePeriod3 = MAX(CASE WHEN rn = 3 THEN CoursePeriod END),CoursePeriod4 = MAX(CASE WHEN rn = 4 THEN CoursePeriod END),Teacher1 = MAX(CASE WHEN rn = 1 THEN Teacher END),Teacher2 = MAX(CASE WHEN rn = 2 THEN Teacher END),Teacher3 = MAX(CASE WHEN rn = 3 THEN Teacher END),Teacher4 = MAX(CASE WHEN rn = 4 THEN Teacher END),....
FROM (
SELECT *,rn = ROW_NUMBER() OVER (ORDER BY courseId)
FROM getFourCoursesByYear(@year)
)
以上是大佬教程为你收集整理的插入来自其他函数的自定义格式和值的行全部内容,希望文章能够帮你解决插入来自其他函数的自定义格式和值的行所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。