当前位置:Gxlcms > mysql > 【当心!】多个like查询会出现大量重复数据

【当心!】多个like查询会出现大量重复数据

时间:2021-07-01 10:21:17 帮助过:12人阅读

多个like查询会出现大量重复数据 无 ===============================问题描述===================================两个表表usersid username1 andy2 jack3 leo4 kimi表carid title userid chnname1 bmw750 1 宝马2 bmw530 1 宝马3 bmw 2 宝马4 benzc2 1 奔驰

多个like查询会出现大量重复数据 <无>
  1. ===============================问题描述===================================
  2. 两个表
  3. 表users
  4. id username
  5. 1 andy
  6. 2 jack
  7. 3 leo
  8. 4 kimi
  9. 表car
  10. id title userid chnname
  11. 1 bmw750 1 宝马
  12. 2 bmw530 1 宝马
  13. 3 bmw 2 宝马
  14. 4 benzc2 1 奔驰
  15. 5 benzE3 2 奔驰
  16. SQL:select * from a.*,b.* from car a inner join username b on a.userid = b.id
  17. 现在需要增加like查询条件 查询title类似于bmw的
  18. select * from a.*,b.* from car a inner join username b on a.userid = b.id and a.title like '%bmw%'
  19. 这个语句会得到三条结果。正确的。但如果我再加上一个like条件就不行
  20. 查询title类似于bmw chnname类似于宝马
  21. select * from a.*,b.* from car a inner join username b on a.userid = b.id and a.title like '%bmw%' or a.chnname like '%宝马%'
  22. 这样的话会得到一大堆的重复数据
  23. ==============================分析=================================
  24. 之所以会得到那么多重复数据是因为上面的SQL相当于
  25. select a.*,b.*
  26. from car a
  27. inner join username b
  28. on a.userid = b.id AND a.title like '%bmw%'
  29. UNION ALL
  30. select a.*,b.*
  31. from car a
  32. inner join username b
  33. on a.chnname like '%宝马%'
  34. ===============================解决=================================
  35. 在like条件中加()或者使用where
  36. 1.select * from a.*,b.* from car a inner join username b on a.userid = b.id and
  37. (a.title like '%bmw%' or a.chnname like '%宝马%')
  38. 2.select a.*,b.* from car a inner join username b on a.userid = b.id
  39. where a.title like '%bmw%' or a.chnname like '%宝马%'

人气教程排行