很多高性能的应用都会对关联查询进行分解. 简单地,可以对每个表进行一次单表查询,然后将结果在应用程序中进行关联.例如,下面这个查询: select * from tag join tag_post on tag_post.tag_id=tag.id join post on tag_post.post_id=post.id where tag.tag=’mysql’; 可以分解成下面这些查询来代替: Select * from tag where tag=’mysql’; Select * fr…
听了猫大师的课,对Oracle CBO又加深了一步理解: 单表选择率: selectivity=1/ndv*a4nulls ocard来自dba_tables.num_rows ndv 来自dba_tab_col_statistics中的num_distinct where 条件为 owner='' AND table_name='' and column_name='' a4nulls 来自dba_tab_col_statistics中的num_nulls where 条件为 owner='…
查询结构 --SQL语句的执行原理以及语法结构: /* SELECT * | 列名1[,列名2...] | 表达式 FROM 表名 [表的别名] WHERE 分组前的筛选条件 GROUP BY 列名1[,列名2...] HAVING 分组后的筛选条件 ORDER BY 列名1[ASC,列名2 DESC...]; */ 查询顺序 (1)FROM (2)WHERE (3)GROUP BY (4)HAVING (5)SELECT (6)ORDER BY 语法解析: (1)*表示表中的所有列. (2)列…