创建视图的时候选择表的顺序不一样,会有不同的视图结果呈现。反应到创建视图的语句上就是inner join cross join这些字段的差别上。
下面就举一个例子。
先将TB_Course表拖出,再拖出TER_CourseQuestionTypeLink表,最后拖出TE_QuestionType表。这里值得注意的是,在TB_Course表中,没有QuestionType的外键字段,而是将两者的关联放到了TER_CourseQuestionTypeLink表中。在两个基本表中有主键,而在关联表中没有外键关联。
SELECT dbo.TER_CourseQuestionTypeLink.CourseId, dbo.TER_CourseQuestionTypeLink.QuestionTypeId, dbo.TB_Course.CourseName,
dbo.TE_QuestionType.QuestionTypeName
FROM dbo.TB_Course INNER JOIN
dbo.TER_CourseQuestionTypeLink ON dbo.TB_Course.CourseID = dbo.TER_CourseQuestionTypeLink.CourseId INNER JOIN
dbo.TE_QuestionType ON dbo.TER_CourseQuestionTypeLink.QuestionTypeId = dbo.TE_QuestionType.QuestionTypeId关联图如下:

如果换做TB_Course——TE_QuestionType——TER_CourseQuestionTypeLink的顺序拖出,那么视图的创建的字段就是Cross join了,自动生成的语句如下:
SELECT dbo.TER_CourseQuestionTypeLink.CourseId, dbo.TER_CourseQuestionTypeLink.QuestionTypeId, dbo.TB_Course.CourseName,
dbo.TE_QuestionType.QuestionTypeName
FROM dbo.TB_Course INNER JOIN
dbo.TER_CourseQuestionTypeLink ON dbo.TB_Course.CourseID = dbo.TER_CourseQuestionTypeLink.CourseId CROSS JOIN
dbo.TE_QuestionType关联图如下:

其实在细节之处正式体现软件强大之处,sql可以自动的根据视图中表的创建顺序,识别内部的字段,从这些细小之处,可以学习到良好的软件设计思路,向高人学习。
本文通过实例展示了在创建数据库视图时,不同表的加入顺序如何影响最终视图的结构和查询结果。特别是通过对比inner join与cross join的效果,解释了软件如何智能地识别并调整字段连接方式。
2387

被折叠的 条评论
为什么被折叠?



