mysql函数IFNULL的使用替换递归方法
在电商行业经常遇到的问题就是类目与类目以及类目与商品的关系。
如果要查询一级类目下的所有商品
常规做法是先查询该一级类目下所有的二级类目,再由二级类目查询所有的三级类目,直到最后一级,再查询出对应的商品。
首先想到的方法就是递归。
偶然发现mysql的IFNULL方法其实可以替换常规的递归方法。
先说下IFNULL方法的使用:
IFNULL的作用是什么?下面一个简单的sql和结果说明,如果IFNULL(a,b),a接收的值为null,则返回b,否则返回a;
例如:根据1级类目查询出该一级类目下所有最底层类目的id
这个left join几次是根据你有几层类目来定的。如果只有3层类目,则上面的c4就可以去掉。
这样一个sql就可以代替一个递归方法。
hello world!!!