原文:在论坛中出现的比较难的sql问题:11(字符分拆 多关键字匹配问题)


最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了。

所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。

这个语句怎么写?

http://bbs.csdn.net/topics/390490832?page=1

我有一张表:CarRule

有下面这些列和数据

ID    Keywords

1     时速50%、 不到100%

2     违反禁令标志

3     违反规定停放、拒绝立即驶离、妨碍其他车辆

我要查询这个CarRule表,根据关键字获取ID

例如:机动车行驶超过规定时速50%以上不到100%的  就能获取到  ID=1

      机动车违反禁令标志的                     就能获取到  ID=2

      违反规定停放、临时停车且驾驶人不在现场或驾驶人虽在现场拒绝立即驶离,妨碍其他车辆、行人通行的         

就能获取到  ID=3

这个查询我怎么写。

我的解法:


  1. --1.先建立一个函数,通过分隔符来拆分keywords成多个关键字
  2. create function dbo.fn_splitSTR
  3. (
  4. @s varchar(8000), --要分拆的字符串
  5. @split varchar(10) --分隔字符
  6. )
  7. returns @re table( --要返回的临时表
  8. col varchar(1000) --临时表中的列
  9. )
  10. as
  11. begin
  12. declare @len int
  13. set @len = LEN(@split) --分隔符不一定就是一个字符,可能是2个字符
  14. while CHARINDEX(@split,@s) >0
  15. begin
  16. insert into @re
  17. values(left(@s,charindex(@split,@s) - 1))
  18. set @s = STUFF(@s,1,charindex(@split,@s) - 1 + @len ,'') --覆盖:字符串以及分隔符
  19. end
  20. insert into @re values(@s)
  21. return --返回临时表
  22. end
  23. go
  24. --2.建表
  25. DECLARE @CarRule TABLE(id INT,Keywords VARCHAR(100))
  26. INSERT INTO @carrule
  27. VALUES(1,'时速50%、不到100%'),
  28. (2,'违反禁令标志'),
  29. (3,'违反规定停放、拒绝立即驶离、妨碍其他车辆')
  30. ;WITH split --拆分关键字
  31. as
  32. (
  33. SELECT c.id,
  34. c.keywords,
  35. f.col
  36. FROM @carrule c
  37. CROSS apply dbo.fn_splitSTR(c.keywords,'、') f
  38. )
  39. --3.第1个查询
  40. SELECT s.id,
  41. s.keywords
  42. FROM split s
  43. INNER JOIN
  44. (
  45. SELECT s.id,
  46. s.keywords,
  47. count(col) AS split_str_count --拆分成了几个关键字
  48. FROM split s
  49. GROUP BY s.id,
  50. s.keywords
  51. ) ss
  52. ON s.id = ss.id
  53. WHERE charindex(s.col,'机动车行驶超过规定时速50%以上不到100%的') > 0
  54. GROUP BY s.id,
  55. s.keywords
  56. HAVING count(*) = max(ss.split_str_count) --比如第一条记录拆分成了2个关键词,那么在匹配时要2个都匹配上了,才算为匹配

第2个查询:


  1. DECLARE @CarRule TABLE(id INT,Keywords VARCHAR(100))
  2. INSERT INTO @carrule
  3. VALUES(1,'时速50%、不到100%'),
  4. (2,'违反禁令标志'),
  5. (3,'违反规定停放、拒绝立即驶离、妨碍其他车辆')
  6. ;WITH split --拆分关键字
  7. as
  8. (
  9. SELECT c.id,
  10. c.keywords,
  11. f.col
  12. FROM @carrule c
  13. CROSS apply dbo.fn_splitSTR(c.keywords,'、') f
  14. )
  15. --3.
  16. SELECT s.id,
  17. s.keywords
  18. FROM split s
  19. INNER JOIN
  20. (
  21. SELECT s.id,
  22. s.keywords,
  23. count(col) AS split_str_count --拆分成了几个关键字
  24. FROM split s
  25. GROUP BY s.id,
  26. s.keywords
  27. ) ss
  28. ON s.id = ss.id
  29. WHERE charindex(s.col,'机动车违反禁令标志的') > 0
  30. GROUP BY s.id,
  31. s.keywords
  32. HAVING count(*) = max(ss.split_str_count) --比如第一条记录拆分成了2个关键词,那么在匹配时要2个都匹配上了,才算为匹配

第3个查询:


  1. DECLARE @CarRule TABLE(id INT,Keywords VARCHAR(100))
  2. INSERT INTO @carrule
  3. VALUES(1,'时速50%、不到100%'),
  4. (2,'违反禁令标志'),
  5. (3,'违反规定停放、拒绝立即驶离、妨碍其他车辆')
  6. ;WITH split --拆分关键字
  7. as
  8. (
  9. SELECT c.id,
  10. c.keywords,
  11. f.col
  12. FROM @carrule c
  13. CROSS apply dbo.fn_splitSTR(c.keywords,'、') f
  14. )
  15. --3.
  16. SELECT s.id,
  17. s.keywords
  18. FROM split s
  19. INNER JOIN
  20. (
  21. SELECT s.id,
  22. s.keywords,
  23. count(col) AS split_str_count --拆分成了几个关键字
  24. FROM split s
  25. GROUP BY s.id,
  26. s.keywords
  27. ) ss
  28. ON s.id = ss.id
  29. WHERE charindex(s.col,'违反规定停放、临时停车且驾驶人不在现场或驾驶人虽在现场拒绝立即驶离,妨碍其他车辆、行人通行的就能获取到') > 0
  30. GROUP BY s.id,
  31. s.keywords
  32. HAVING count(*) = max(ss.split_str_count) --比如第一条记录拆分成了2个关键词,那么在匹配时要2个都匹配上了,才算为匹配
发布了416 篇原创文章 · 获赞 135 · 访问量 94万+

在论坛中出现的比较难的sql问题:11(字符分拆 多关键字匹配问题)的更多相关文章

  1. 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)

    原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  2. 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)

    原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...

  3. 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)

    原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...

  4. 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)

    原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  5. 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)

    原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  6. 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)

    原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  7. 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)

    原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...

  8. 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)

    原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...

  9. 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)

    原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

随机推荐

  1. Socket: Java Socket 几个重要的TCP/IP选项解析(转)

    Socket选择可以指定Socket类发送和接受数据的方式.在JDK1.4中共有8个Socket选择可以设置.这8个选项都定义在java.net.SocketOptions接口中.定义如下: publ ...

  2. FFmpeg: mac下手动编译android上使用的FFmpeg(支持x86、armeabi-v7a、arm64-v8a)

    之前一直在linux下编译FFmpeg,最近换电脑了,尝试了下在mac下编译ffmpeg,特记录之. 一. 准备工作 1. 下载FFmpeg.(http://ffmpeg.org/download.h ...

  3. python获取公网ip的几种方式

    python获取公网ip的几种方式 转 https://blog.csdn.net/conquerwave/article/details/77666226 from urllib2 import u ...

  4. Flutter 中SimpleDialog简单弹窗使用

    import 'package:flutter/material.dart'; import 'dart:async'; enum Option { A, B, C } class SimpleDia ...

  5. python中修改列表元素的方法

    一.在for循环中直接更改列表中元素的值不会起作用: 如: l = list(range(10)[::2]) print (l) for n in l: n = 0 print (l) 运行结果: [ ...

  6. 使用 evo 工具评测 VI ORB SLAM2 在 EuRoC 上的结果

    http://www.liuxiao.org/2017/11/%E4%BD%BF%E7%94%A8-evo-%E5%B7%A5%E5%85%B7%E8%AF%84%E6%B5%8B-vi-orb-sl ...

  7. 数据分析入门——numpy

    一.什么是numpy Numpy提供了一个在Python中做科学计算的基础库,重在数值计算,主要用于处理多维数组(矩阵)的库.用来存储和处理大型矩阵,比Python自身的嵌套列表结构要高效的多.本身是 ...

  8. ES6深入浅出-13 Proxy 与 Reflect-3.Vue 3 将用 Proxy 改写

    如果说想打印出来年龄,但是有没有年龄的这个key值 把创建年龄写在一个按钮上面 通过一个事件来做. 点击创建年龄的按钮,给obj.age设置为18,但是页面的双向绑定并没有显示出来. 因为不响应式,为 ...

  9. 【DataBase】H2 DateBase的简单使用

    H2介绍 H2是一个开源的嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一个十分方便的web控制台用于操作和管理数据库内容. H2还提供兼容模式,可以兼容一些主流的数据库,因此 ...

  10. Qt编写自定义控件71-圆弧进度条

    一.前言 现在web形式的图表框架非常流行,国产代表就是echart,本人用过几次,三个字屌爆了来形容,非常强大,而且易用性也非常棒,还是开源免费的,使用起来不要太爽,内置的各种图表和仪表盘等非常丰富 ...