加速查询的sql语句

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)。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值