今天在review代码查看SQL语句时突然对没有指定排序方式的SQL语句返回怎样的排序结构感兴趣!在某些场景中返回结果中的元素到底是按照什么顺序以什么字段排序的将直接影响到整个业务是否正确。例如myBatis中语句如下:
<select id="get_by_id" resultMap="App" parameterClass="java.lang.Long">
select <include refid="fileds"/> from table_a where id = #id# and type = 2 and state != 0
</select>
排查问题
那么到底MySQL在没有指定排序字段以及排序顺序时是按照什么规则排序呢?最早猜测是按照主键排序,即在table_a表中按照id字段进行降序排列。那么到底是否正确呢?为了验证猜测,在本地通过Navicat8对这个猜测进行了验证:SELECT * FROM test_a查询结果:
发现查询结果并没有按照猜测的方式进行排序,并且查询结果没有任何规律可循。这样看来如果按照上述的方式处理业务是很有可能出现问题的。仔细想了一下,这个问题应该和数据库存储引擎有关系,然后再网上查阅了一下这个问题,