做题笔记:SQL Sever 方式做牛客SQL的题目--VQ34

–VQ34 话题的分布情况
牛客有评论记录表comment_detail,输出所有第二话题为1002的评论对应的第一话题subject_id1的数量cnt,按照第一话题升序排序,查询返回结果名称和顺序为:
subject_id1|cnt

表的创建及数据添加:

drop table if exists comment_detail;
create table comment_detail
(id          int,--'ID',comment     text,--'评论内容',subject_set text,--'所属话题, 第一所属,第二所属, ....... 逗号分隔',type_id     int,--'被标记类型'
);insert into comment_detail
values (1, '试一 下吧', '1001,1002,1003', 100);
insert into comment_detail
values (2, '是吗?', '10086,1002,10010', 101);
insert into comment_detail
values (3, '是的,真的啊!', '', 102);
insert into comment_detail
values (4, 'hello world', '11002,1002', 100);
insert into comment_detail
values (5, '你好,中国!', '11002,11024', 104);
insert into comment_detail
values (6, '天了噜,我表示不敢相信', '', null);
insert into comment_detail
values (7, '第一人2/3错误率, 第二人一定是1/2错误率, 相乘得1/3', '', 101);
insert into comment_detail
values (8, '看不懂。。。', '11022,1002', 102);
insert into comment_detail
values (9, '第2个括号里写错了,应该是(770 - (512-1))', '11022,1002', null);
insert into comment_detail
values (10, '大家猜猜我是谁', '142197,1002,143834', 104);
insert into comment_detail
values (11, '假设有 长度为2  那么  m= 2 ,f = 0 ,r = 1   那么计算结果应该是    2+1-0  mod 2  = 1', '11075', 100);
insert into comment_detail
values (12, '可以在线oj,( ^_^ )不错嘛', '11003', null);
insert into comment_detail
values (13, '年轻人可千万别努力错了方向啊~', '11002', null);
insert into comment_detail
values (14, '老师教过不会就选C,所以 应该是选择排序!', '', null);
insert into comment_detail
values (15, 'xxmmmxmx', '', null);
insert into comment_detail
values (16, 's*c/(a+b) ..', '11081', 100);
insert into comment_detail
values (17, '优点:该方法易于理解,缺点:实现过程太复杂了', '11002,1002,11004', 101);
insert into comment_detail
values (18, '求送书', '11002', 102);
insert into comment_detail
values (19, '我来看看', '11234,11007,11053', 100);
insert into comment_detail
values (20, '这个题目好难,求解答:)', '11022,11023', 101);
insert into comment_detail
values (21, '楼主好人~', '11022', 103);
insert into comment_detail
values (22, '我要报名 不过我名字的颜色是?', '', null);

查询如下:

 select subject_id1,count(subject_id1) as cntfrom (select SUBSTRING(subject_set, 1, CHARINDEX(',', subject_set) - 1) as subject_id1,	--查询第一个字符到字符串中第一个逗号前的字符即第一话题,作为要求的subject_id1列SUBSTRING(subject_set, CHARINDEX(',', subject_set) + 1, DATALENGTH('1002')) as sub2,--讨论如果第二话题为1002,且后面不带话题,查询字符串中第一逗号至len('1002')个长度的字符作为待比较列sub2SUBSTRING(subject_set, CHARINDEX(',', subject_set) + 1, DATALENGTH('1002,')) as sub3--讨论如果第二话题为1002,后面带其他话题,查询字符串中第一逗号至len('1002,')个长度的字符作为待比较列sub3from comment_detail) twhere sub2  = '1002' or sub3= '1002,'	--当满足讨论的两种条件时,符合题目要求,即第二话题为‘1002’group by subject_id1order by subject_id1

在上述查询中:
CHARINDEX函数是在SQL Server中用于查找指定子字符串在字符串中的位置的函数。它返回子字符串在字符串中第一次出现的位置,如果找不到子字符串,则返回0。
以下是CHARINDEX函数的语法:

CHARINDEX ( expressionToFind , expressionToSearch [ , start_location ] )

expressionToFind:要查找的子字符串。
expressionToSearch:要在其中查找子字符串的字符串。
start_location(可选):指定从搜索字符串的哪个位置开始查找子字符串。默认为1。
可以实现大小写不敏感的匹配,使用CHARINDEX函数,可以方便地查找指定子字符串在字符串中的位置。

SUBSTRING函数是在SQL Server中用于从字符串中提取子字符串的函数。它可以从给定的位置开始,返回指定长度的子字符串。

以下是SUBSTRING函数的语法:

SUBSTRING ( expression , start_position , length )

expression:要提取子字符串的原始字符串。
start_position:指定开始提取的位置,从1开始计数。
length:指定要提取的子字符串的长度。
Note:
<1> 如果省略length参数,则SUBSTRING函数将提取从start_position位置开始到字符串结尾的子字符串。如果start_position的值超过了字符串的长度,将返回空字符串。
<2> SQL Server中的字符串索引从1开始,而不是从0开始。因此,在使用SUBSTRING函数时,要确保start_position的值正确并在有效范围内。
<3> 使用SUBSTRING函数可以方便地提取字符串中的子字符串,根据需要指定起始位置和长度。

DATALENGTH函数是在SQL Server中用于获取二进制数据或字符串的字节数的函数。它返回指定表达式的字节长度,无论是二进制数据还是字符数据。
以下是DATALENGTH函数的语法:

DATALENGTH ( expression )

Note:
<1> DATALENGTH函数对于字符串类型和二进制数据类型返回的是字节数,而不是字符数。在处理Unicode字符(如NCHAR或NVARCHAR类型)时,每个字符占用两个字节。因此,如果想获取字符串的字符数,请使用LEN函数。
<2> 使用DATALENGTH函数可以方便地获取二进制数据或字符串的字节数,根据需要取得正确的长度信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/198593.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java三种代理模式:静态代理、动态代理和CGLIB代理

Java三种代理模式&#xff1a;静态代理、动态代理和CGLIB代理 代理模式 代理模式是23种设计模式种的一种。代理模式是一种结构型设计模式&#xff0c;它允许为其他对象提供一个替代品或占位符&#xff0c;以控制对这个对象的访问。代理模式可以在不修改被代理对象的基础上&am…

解锁网络速度的利器:CDN加速技术探析

随着互联网的飞速发展&#xff0c;网络速度成为了人们关注的焦点之一。对于许多网民来说&#xff0c;快速、稳定的网络连接已经成为日常生活中不可或缺的一部分。然而&#xff0c;随着网络流量的不断增加&#xff0c;网站访问速度的问题也逐渐凸显。在这个背景下&#xff0c;CD…

C语言之多重循环

目录 二重循环 用break语句强制结束循环 显示图形 绘制等腰直角三角形 多重循环 continue语句 将循环语句的循环体作为循环语句&#xff0c;就可以进行二重、三重循环。这样的循环称为多重循环。 我们先来了解二重循环 二重循环 在之前我们学习到的循环中的程序都比较简…

Java---异常

文章目录 1. 异常概述2. try...catch3. Throwable成员方法4. 编译时异常和运行时异常区别5. 异常处理之throws6. 自定义异常7. throws和throw的区别 1. 异常概述 1. 异常&#xff1a;就是程序中出现了不正常的情况。 2. Error&#xff1a;严重问题&#xff0c;不需要处理。Exce…

【带头学C++】----- 九、类和对象 ---- 9.4 拷贝构造函数、赋值

目录 9.4 拷贝构造函数、赋值 9.4.1 定义拷贝构造函数 9.4.2 拷贝构造和无参构造、有参构造的关系 9.4.3 拷贝构造的几种调用形式 1、旧对象给新对象初始化&#xff0c;调用拷贝构造 2、给对象取别名不会调用拷贝构造 3、普通对象作为函数参数&#xff0c;调用函数时会发…

STM32-GPIO编程

一、GPIO 1.1 基本概念 GPIO&#xff08;General-purpose input/output&#xff09;通用输入输出接口 --GP 通用 --I input输入 --o output输出 通用输入输出接口GPIO是嵌入式系统、单片机开发过程中最常用的接口&#xff0c;用户可以通过编程灵活的对接口进行控制&#xff0c;…

ArcGIS提取DEM中的山脉范围

已知数据&#xff1a;DEM文件ASTGTM_N00E118E.img 使用软件&#xff1a;ArcMap 要求&#xff1a;对数据进行操作&#xff0c;提取数据文件中的山脉范围 下面开始操作&#xff1a; 1、 打开ArcMap将DEM文件ASTGTM_N00E118E.img添加到数据框。 2、 接下来我们打开spatial ana…

虚幻学习笔记8—蓝图操作其他虚幻模块

一、前言 蓝图不仅可以相互之间操作和通信&#xff0c;其他的资源、模块也有操作和通信的方法。文本主要针对蓝图和材质、Niagara、编辑器的通信进行讲解。 二、实现 2.1、蓝图和材质 1&#xff09;首先&#xff0c;在材质蓝图中按住“4鼠标左键”创建一个参数为四维向量的参…

Kafka中的auto-offset-reset配置

Kafka这个服务在启动时会依赖于Zookeeper&#xff0c;Kafka相关的部分数据也会存储在Zookeeper中。如果kafka或者Zookeeper中存在脏数据的话&#xff08;即错误数据&#xff09;&#xff0c;这个时候虽然生产者可以正常生产消息&#xff0c;但是消费者会出现无法正常消费消息的…

子串回文 I. Barbecue

Problem - I - Codeforces 题目大意&#xff1a;给一个字符串 s t r str str&#xff0c;有 q q q次博弈。每次博弈给出 l , r l,r l,r表示字符串左右边界&#xff0c;每次一个人可以从该子串的首或尾删除一个字符&#xff0c;如果操作前后是回文串则操作的人输。询问谁会赢&a…

【小工具分享】分享一个小工具---可视化数据结构 (初学者建议收藏)

工具链接&#xff1a; 可视化数据结构 这里支持大量数据结构地演示&#xff0c;相当全面&#xff0c;对于初学数据结构或者想更直观感受某个数据结构地实现有很大帮助&#xff0c;能直观的看到该数据结构的增删改查&#xff0c;帮助我们理解某一数据结构的性能~ 下面我演示一下…

揭秘MQTT:为何它是物联网的首选协议?

文章目录 MQTT 协议简介概览MQTT 与其他协议对比MQTT vs HTTPMQTT vs XMPP 为什么 MQTT 是适用于物联网的最佳协议&#xff1f;轻量高效&#xff0c;节省带宽可靠的消息传递海量连接支持安全的双向通信在线状态感知 MQTT 5.0 与 3.1.1MQTT 服务器MQTT 客户端 MQTT 协议简介 概…

设计模式之代理模式(1)

目录 概述定义应用场景主要角色类图 详述基本代码应用实例符合的设计原则 总结 概述 定义 代理模式是一种结构型设计模式&#xff0c;它允许通过一个代理对象来控制对原始对象的访问。代理对象可以在不改变原始对象的情况下&#xff0c;增加一些额外的功能&#xff0c;例如权限…

如何做好一个软件开发项目经理?

要成为一名优秀的软件开发项目经理&#xff0c;需要具备一定的技术知识和管理能力。下面是学习和发展软件开发项目经理职业所需的关键能力和工作内容。 首先&#xff0c;作为软件开发项目经理&#xff0c;你需要具备扎实的软件开发知识和技能。这包括熟悉常用的编程语言、开发框…

Python教程75:textwrap模块 — 文本自动换行与填充

TextWrap模块是一个Python模块&#xff0c;它提供了一些函数和方法来处理文本字符串的包装和填充。这个模块的主要功能是将一个长字符串根据指定的宽度分成多行&#xff0c;可以用于格式化文本输出&#xff0c;使其在指定的行数内完成显示。这个过程通常用于控制文本在终端、文…

面向注解编程—Spring 注解看这一篇就够了

面向注解编程—Spring 注解大全之IOC篇 Spring的一个核心功能是IOC&#xff0c;就是将Bean初始化加载到容器中&#xff0c;调用的时候直接注入即可&#xff0c;使用注解可以大大提高了开发效率&#xff01;。 Bean英文意为 豆子 理解起来就是豆荚里的豌豆&#xff0c;豆荚就是…

.Net core 6.0 升8.0

1 Update Visual Studio 2 3 用Nutget 更新不同套件版本 更新后结果如下&#xff1a;

第四期丨酷雷曼无人机技能培训

第4期无人机技能培训 2023年10月25日&#xff0c;酷雷曼无人机技能培训及执照考试第四期成功举办&#xff0c;自7月份首期开办以来&#xff0c;已按照每月一期的惯例连续举办四期&#xff0c;取得了极为热烈的反响。 随着无人机培训的重要性及影响力逐渐扩大&#xff0c;参加培…

UE4/UE5 材质实现带框环形进度条

UE4/UE5 材质实现带框环形进度条 此处使用版本&#xff1a;UE4.27 原理&#xff1a;大圆减小圆可以得到圆环&#xff0c;大圆环减小圆环&#xff0c;可以得到圆环外围线框 实现效果&#xff1a; 实现&#xff08;为了给大家放进一张面前能看的图&#xff0c;我费劲了心思&…

从 MQTT、InfluxDB 将数据无缝接入 TDengine,接入功能与 Logstash 类似

利用 TDengine Enterprise 和 TDengine Cloud 的数据接入功能&#xff0c;我们现在能够将 MQTT、InfluxDB 中的数据通过规则无缝转换至 TDengine 中&#xff0c;在降低成本的同时&#xff0c;也为用户的数据转换工作提供了极大的便捷性。由于该功能在实现及使用上与 Logstash 类…