1、多表查询,使用内连接或外连接,内连接主要查询双方都符合的条件,外连接又分为左外连接和右外连接;select后跟具体的字段名,即便是全部写所有的字段名,也比只使用*要快。三个以上的表连起来查询,用多个inner join或left join、right join来连接。
如:SELECT t.terminal_id,u.username,a.serial_no,... FROM ems_terminal_equipment t INNER JOIN ems_user_record u ON u.terminal_id=t.id INNER JOIN ems_attachment a ON a.terminal_id=t.id ORDER BY u.terminal_num
2、使用子查询,SELECT (SELECT NAME FROM ems_department_directory department WHERE department.id=terminal.first_dep) AS dep1,(SELECT NAME FROM ems_department_directory department WHERE department.id=terminal.second_dep) AS dep2,(SELECT NAME FROM ems_department_directory department WHERE department.id=terminal.third_dep) AS dep3,inter.subscriber_alias FROM ems_terminal_number_info terminal INNER JOIN atia_interconnect_packet inter ON inter.subscriber_alias=terminal.terminal_number
这种情况多用于,类型、型号之类的单独建的一个表,在查询中放在子查询中,因为数量不是很多,查询较为方便、高效。
3、建立临时表。这也是一个不错的方法,
create tmporary table cust_with_balance;
insert into cust_with_balance SELECT cust.name,rcvbles.balance,……other columns
FROM cust,rcvbles
WHERE cust.customer_id = rcvlbes.customer_id
AND rcvblls.balance>0
ORDER BY cust.name
然后以下面的方式在临时表中查询:
SELECT * FROM cust_with_balance
WHERE postcode>“98000”
4、建立索引:
a、在经常进行连接,但是没有指定为外键的列上建立索引,而不经常连接的字段则由优化器自动生成索引。
b、在频繁进行排序或分组(即进行group by或order by操作)的列上建立索引。
c、如果待排序的列有多个,可以在这些列上建立复合索引(compound index)。