from ProductCategory ---- 从ProductCategory 表查询数据
ProductCategory p -----给表ProductCategory 取了个别名,就是简称
where pname = :name -----这是查询语句的条件,表ProductCategory 的name = :name
:name ----- 这是个变量,要根据上下文才能知道具体的值
严格上来说是没有要求的,他们有两种写法,一种是ANSI_SQL,一种是Trans_SQL
ANSI-SQL:
select from table1,table2,table3 where table1ID=table2ID and Table3id = table2PID
Trans-SQL:
select from table1 join table2 on table1ID = table2ID join table3 on table2PID = table3ID
也就是说两种写法看一下连接条件是在from中还是直接写在where条件中了!
严格意义上来说,连接顺序可以随便写的。但是两种还是有差别的。一般要求有顺序,但这个顺序不是强制要求——而是为了数据库效率,也就是语句的性能上是有要求的!
在ANSI中,一般不作要求,因为数据库会自动优化语句,在where中的条件,数据库根据自己的规则和学习在执行时条件顺序与你写时的未必是一样的。达到了自动优化的目的——但这种优化只是数据库的自认为,他有可能优化后的语句反倒慢了,这时你需要关闭数据库优化功能,让他按你写的顺序执行。而在from中时数据库不会自己优化,所以此时你应该注意顺序。
不管哪一种情况,建议顺序都是先生成连接条件结果较少的,也就是说在语句执行结果集时,结果集尽量的小,不要大,所以对于连接时两个小数据表先连接,然后再是大表连接。但这个顺序只是建议——严格上却没有任何要求。
以上就是关于sql数据库from语句问题全部的内容,包括:sql数据库from语句问题、sql连接查询语句中from子句中表的顺序有什么要求、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)