在搜索接口的开发中,经常会遇到需要模糊匹配的场景,记录一下MySQL和MongoDB分别是怎么做的。

对比

-- SQL:
SELECT * FROM users WHERE username LIKE "%l%"

-- MongoDB:
db.users.find({username: /l/})
// 或者
db.users.find({username: { $regex: 'l'})

LIKE模糊查询username以字母"张"开头的数据(张%)

-- SQL:
SELECT * FROM users WHERE username LIKE "张%"

-- MongoDB:
db.users.find({username: /^张/})

来了老弟
508 声望31 粉丝

纸上得来终觉浅,绝知此事要躬行