在论坛中出现的比较难的sql问题:11(字符分拆 多关键字匹配问题)
原文:在论坛中出现的比较难的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.先建立一个函数,通过分隔符来拆分keywords成多个关键字
-
create function dbo.fn_splitSTR
-
(
-
@s varchar(8000), --要分拆的字符串
-
@split varchar(10) --分隔字符
-
)
-
returns @re table( --要返回的临时表
-
col varchar(1000) --临时表中的列
-
)
-
as
-
begin
-
declare @len int
-
-
set @len = LEN(@split) --分隔符不一定就是一个字符,可能是2个字符
-
-
while CHARINDEX(@split,@s) >0
-
begin
-
insert into @re
-
values(left(@s,charindex(@split,@s) - 1))
-
-
set @s = STUFF(@s,1,charindex(@split,@s) - 1 + @len ,'') --覆盖:字符串以及分隔符
-
end
-
-
insert into @re values(@s)
-
-
return --返回临时表
-
end
-
go
-
-
-
-
--2.建表
-
DECLARE @CarRule TABLE(id INT,Keywords VARCHAR(100))
-
-
-
INSERT INTO @carrule
-
VALUES(1,'时速50%、不到100%'),
-
(2,'违反禁令标志'),
-
(3,'违反规定停放、拒绝立即驶离、妨碍其他车辆')
-
-
-
-
-
;WITH split --拆分关键字
-
as
-
(
-
SELECT c.id,
-
c.keywords,
-
f.col
-
FROM @carrule c
-
CROSS apply dbo.fn_splitSTR(c.keywords,'、') f
-
-
-
)
-
-
-
--3.第1个查询
-
SELECT s.id,
-
s.keywords
-
-
FROM split s
-
INNER JOIN
-
(
-
SELECT s.id,
-
s.keywords,
-
count(col) AS split_str_count --拆分成了几个关键字
-
FROM split s
-
GROUP BY s.id,
-
s.keywords
-
-
) ss
-
ON s.id = ss.id
-
-
WHERE charindex(s.col,'机动车行驶超过规定时速50%以上不到100%的') > 0
-
-
GROUP BY s.id,
-
s.keywords
-
HAVING count(*) = max(ss.split_str_count) --比如第一条记录拆分成了2个关键词,那么在匹配时要2个都匹配上了,才算为匹配
第2个查询:
-
DECLARE @CarRule TABLE(id INT,Keywords VARCHAR(100))
-
-
-
INSERT INTO @carrule
-
VALUES(1,'时速50%、不到100%'),
-
(2,'违反禁令标志'),
-
(3,'违反规定停放、拒绝立即驶离、妨碍其他车辆')
-
-
-
-
-
;WITH split --拆分关键字
-
as
-
(
-
SELECT c.id,
-
c.keywords,
-
f.col
-
FROM @carrule c
-
CROSS apply dbo.fn_splitSTR(c.keywords,'、') f
-
-
-
)
-
-
-
--3.
-
SELECT s.id,
-
s.keywords
-
-
FROM split s
-
INNER JOIN
-
(
-
SELECT s.id,
-
s.keywords,
-
count(col) AS split_str_count --拆分成了几个关键字
-
FROM split s
-
GROUP BY s.id,
-
s.keywords
-
-
) ss
-
ON s.id = ss.id
-
-
WHERE charindex(s.col,'机动车违反禁令标志的') > 0
-
-
GROUP BY s.id,
-
s.keywords
-
HAVING count(*) = max(ss.split_str_count) --比如第一条记录拆分成了2个关键词,那么在匹配时要2个都匹配上了,才算为匹配
第3个查询:
-
DECLARE @CarRule TABLE(id INT,Keywords VARCHAR(100))
-
-
-
INSERT INTO @carrule
-
VALUES(1,'时速50%、不到100%'),
-
(2,'违反禁令标志'),
-
(3,'违反规定停放、拒绝立即驶离、妨碍其他车辆')
-
-
-
-
-
;WITH split --拆分关键字
-
as
-
(
-
SELECT c.id,
-
c.keywords,
-
f.col
-
FROM @carrule c
-
CROSS apply dbo.fn_splitSTR(c.keywords,'、') f
-
-
-
)
-
-
-
--3.
-
SELECT s.id,
-
s.keywords
-
-
FROM split s
-
INNER JOIN
-
(
-
SELECT s.id,
-
s.keywords,
-
count(col) AS split_str_count --拆分成了几个关键字
-
FROM split s
-
GROUP BY s.id,
-
s.keywords
-
-
) ss
-
ON s.id = ss.id
-
-
WHERE charindex(s.col,'违反规定停放、临时停车且驾驶人不在现场或驾驶人虽在现场拒绝立即驶离,妨碍其他车辆、行人通行的就能获取到') > 0
-
-
GROUP BY s.id,
-
s.keywords
-
HAVING count(*) = max(ss.split_str_count) --比如第一条记录拆分成了2个关键词,那么在匹配时要2个都匹配上了,才算为匹配
-
在论坛中出现的比较难的sql问题:11(字符分拆 多关键字匹配问题)的更多相关文章
- 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)
原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)
原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...
- 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)
原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...
- 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)
原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)
原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)
原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)
原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...
- 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)
原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...
- 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)
原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
随机推荐
- Acunetix Web Vulnerability Scanner abbr. AWVS
awvs 中文手册详细版 - 木讷 - 博客园https://www.cnblogs.com/iamver/p/7124718.html Download Acunetix Trialhttps:// ...
- flutter PopupMenuButton弹出式菜单列表
import 'package:flutter/material.dart'; class PopupMenuButtonDemo extends StatefulWidget { @override ...
- Android 打开相册拍照选择多张图片显示
添加依赖: compile 'me.iwf.photopicker:PhotoPicker:0.1.8' compile 'com.jaeger.ninegridimageview:library:1 ...
- 读取Excel,通过Testng完成数据驱动
背景 数据驱动是我们写自动化脚本非常常用的技术,而Testng中数据驱动常用的注解是 @DataProvider,但是这个方法必须返回一个Object[][].最近常有学生问起,如果通过外部文件作为数 ...
- 【444】Data Analysis (shp, arcpy)
ABS suburbs data of AUS 1. Dissolve Merge polygons with the same attribute of "SA2_NAME16&quo ...
- ABAP DEMO33 选择周的搜索帮助
效果图 *&---------------------------------------------------------------------**& Report YCX_02 ...
- egg.js 通过 form 和 ajax 两种方式上传文件并自定义目录和文件名
egg.js 通过 form 和 ajax 两种方式上传文件并自定义目录和文件名 评论:10 · 阅读:8437· 喜欢:0 一.需求 二.CSRF 校验 三.通过 form 表单上传文件 四.通过 ...
- openpyxl,xlrd,win32com,wxpython,logging
目录 一. openpyxl常用操作总结 二. xlrd常用操作总结 三. win32com常用操作总结 四. 自定义异常 五. 判断中文 六. Excel数字字母转换 七. 使用wxpython进行 ...
- tornodo学习之路
tornodo的ioloop是什么?(A) A.事件循环 B.对象循环 C.没有对象不用循环 别人是否可以分析放在本地的cookie?(B) A.否 B.是 WSGI是什么?(A) A.web服务器网 ...
- Uncaught Error: `setOption` should not be called during main process.
主要是自己记笔记用,大佬些莫怪! 使用 echart 出现 :Uncaught Error: `setOption` should not be called during main process. ...
