数据库中复合主键如何查询,sql 语句如何写?

2025-02-23 10:55:55
推荐回答(2个)
回答1:

zwb12340 说的就是错的
首先来说一下你的这两种写法
1.这一个比较快,其实这是把两个SQL 拼接成1个SQL,但是在拼接的时候使用了UNION ,这个过程会排序去重复,这一点上会影响性能。可以把UNION 改成UNION ALL,UNION ALL不会排序去重,可能效率会更好一点
2.这一个不会太快,因为使用in的话,默认是不使用索引的,那么这一个过程会全表扫描,那么就很慢了(我这里说的索引是默认的B+树索引,是自动屏蔽的,如果是BITMAP索引的话,是会使用的),

对于你这个问题的解决,我给以下几个意见
1.首先把UNION改成UNION ALL试一试,看效率怎么样
2.检查是否在product上有没有索引,尽量建一个索引
3.如果以上两个改进之后,还没效果的话,可以在这个表上,基于product建立分区表,使用分区表的话,那么效果会比较明显

回答2:

查询什么,哪个列组合是主键?sql语句复合主键有2种比较常用的写法 ,假如表A ,是以a1,a2组合作为主键,一种是同时写出a1,a2条件,一种是a1||a2作为主键