SQL技术分享和问题交流

发布时间 2023-05-09 14:29:13作者: lucken

1.多数表在建表时考滤了主键,但是应用查询时并没有及是补足索引,多数表没索引,造成查询数据慢。 建议建立标准数据库,并配置索引。

2.分表太细,union多表查询消耗大量服务器的SQL编译时间。 建议分表最小到年即可,要有索引。分表尽量按热数据、冷数据的条件去分,避免用时间等区分。

3.巨大临时表:生成临表过大,占用SQL服务器资源。 建议临表只针对小量的数据时使用

4.Select * Into .... 语句在事务中使用。 建议准备数据的语句移到事务之外

5.查询条件尽量少用SQL函数,直接用SQL字段条件,条件尽量能落在索引上进行查询。

6.查询字段中包含select子查询,造成SQL返回多少条记录该子查询就会执行多少次。 建议集合思维,采用join表关联查询。

7.表的主键字段,数值型比字符串类型效率高。

8.流水号取号方式容易锁表,建议改进采用雪花算法等来替换。。。