46.SQLserver中按照多条件分组:查询每个地方的各种水果的种植数量,新增时,一个地方同时有几种水果,只插入一条记录,同时多种水果之间使用|隔开

1.SQLserver中按照多条件分组

,分组条件包括(一个字段使用|进行分割,如:apple|orange,查询时,apple和orange分别对应一条数据)
例如:SQL如下:

SELECT FROM (
SELECT CDFBM '地方编码', CDFMCC '地方名称',  COUNT(CXXID) '种植数量' 
(CASE CSGMC WHEN '001' THEN '苹果' WHEN '002' THEN '李子' WHEN '003' THEN '香蕉' WHEN '004' THEN '梨' WHEN '005' THEN '葡萄' WHEN '006' THEN '蓝莓' WHEN '007' THEN '荔枝' ELSE value END)  '水果类型'
FROM (
SELECT A.IBRJBXXID, A.CJMXXID, D.CXZBM, D.CXZMC, value 
FROM YHPHS..TB_MBGL_HZXX A WITH(NOLOCK) 
INNER JOIN YHPHS.dbo.TB_JGXX D WITH(NOLOCK)ON A.CCJJGBM=D.CJGBM
CROSS APPLY STRING_SPLIT(A.CBRLX, '|')
WHERE CZT=1--  AND value='007'
) B 
GROUP BY CSGMC , CDFBM , CDFMCC
)C
GROUP BY  CSGMC , CDFBM , CDFMCC


2.Cross apply的作用:

无关联条件强制表之间关联

apply有两种形式: cross apply 和 outer apply

区别在于指定OUTER,意味着结果集中将包含使右表表达式为空的左表表达式中的行,

而指定CROSS,则相反,结果集中不包含使右表表达式为空的左表表达式中的行。

零、cross apply的原理:
<left_table>  {cross|outer} apply <right_table>

它是先得出右表里的数据,然后把此数据一条一条的放入左表表式中,分别得出结果集,最后把结果集整合到一起就是最终的返回结果集了

详解:(拆分后的数据 ,像for循环一样 ,一条一条的进入到left表中, 然后返回一个集合 ,最后把所有的集合整合到一块  就是最终的结果)

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

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

相关文章

Mybatis-plus 自动填充字段

需要注意的是&#xff0c;MetaObjectHandler 对Mybatis-plus 自动生成的 CRUD 方法起作用&#xff0c;对于手写 XML 文件的 insert、update 语句&#xff0c;不会直接起作用。 package com.ruoyi.common.mybatisplus;import com.baomidou.mybatisplus.core.handlers.MetaObjec…

python虚拟环境下 .gitignore 要忽略什么

在Python虚拟环境中&#xff0c;.gitignore 文件用于告诉 Git 哪些文件和目录是不需要添加到版本控制中的。以下是一个典型的 Python 虚拟环境中 .gitignore 文件的内容&#xff1a; # Byte-compiled / optimized / DLL files __pycache__/ *.py[cod] *$py.class# C extension…

统信UOS1070上配置文件管理器默认属性01

原文链接&#xff1a;统信UOS 1070上配置文件管理器默认属性01 Hello&#xff0c;大家好啊&#xff01;今天给大家带来一篇关于在统信UOS 1070上配置文件管理器默认属性的文章。文件管理器是我们日常操作系统使用中非常重要的工具&#xff0c;了解如何配置其默认属性可以极大地…

apache poi 插入“下一页分节符”并设置下一节纸张横向的一种方法

一、需求描述 我们知道&#xff0c;有时在word中需要同时存在不同的节&#xff0c;部分页面需要竖向、部分页面需要横向。本文就是用java调用apache poi来实现用代码生成上述效果。下图是本文实现的效果&#xff0c;供各位看官查阅&#xff0c;本文以一篇课文为例&#xff0c;…

小陈的容器镜像站

小陈的容器镜像站 背景 由于不可抗力原因建立了镜像站&#xff0c;支持多平台容器镜像代理。 镜像使用优先级&#xff1a;官方地址 > 镜像地址 > 阿里云地址 替换地址 gcr.io >>>>> gcr.chenby.cnquay.io >>>>> quay.chenby.cng…

整理好了!2024年最常见 20 道分布式、微服务面试题(五)

上一篇地址&#xff1a;整理好了&#xff01;2024年最常见 20 道分布式、微服务面试题&#xff08;四&#xff09;-CSDN博客 九、什么是API网关&#xff0c;它在微服务架构中扮演什么角色&#xff1f; API网关&#xff08;Application Programming Interface Gateway&#xf…

数据库的基础概念

1、什么是数据库&#xff1f; 引用百度词条 数据库&#xff08;Database&#xff09;是按照数据结构来组织、存储和管理数据的仓库&#xff0c;是一个长期存储在计算机内的、有组织的、可共享的、统一管理的大量数据的集合&#xff0c;可视为电子化的文件柜。   数据库技术是…

Linux系统推出VB6开发IDE了?Gambas,Linux脚本编写

第一个Linux程序&#xff0c;加法计算加弹窗对话框,Gambas,linux版的类似VB6的IDE开发环境 一开始想用VB6的Clng函数转成整数&#xff0c;没这函数。 输入3个字母才有智能提示&#xff0c;这点没做好 没有msgbox函数&#xff0c;要用messagebox.warning 如果可以添加函数别名就…

uniapp 使用秋云ucharts,实现线状图横线滚动

其实仔细阅读官网说明文档&#xff0c;能找到答案&#xff0c;但是咱们着急实现功能&#xff0c;直接点上代码。 *标签上注意的是需要设置:ontouch"true"* <view class"" style"width:100%;height:610rpx;"><qiun-data-charts type&q…

[书生·浦语大模型实战营]——第六节 Lagent AgentLego 智能体应用搭建

1. 概述和前期准备 1.1 Lagent是什么 Lagent 是一个轻量级开源智能体框架&#xff0c;旨在让用户可以高效地构建基于大语言模型的智能体。同时它也提供了一些典型工具以增强大语言模型的能力。 Lagent 目前已经支持了包括 AutoGPT、ReAct 等在内的多个经典智能体范式&#x…

通过双模式对抗提示越狱视觉语言模型

最近&#xff0c;将视觉整合到大型语言模型&#xff08;LLMs&#xff09;中的兴趣显著增加&#xff0c;催生了大型视觉语言模型&#xff08;LVLMs&#xff09;。这些模型结合了视觉和文本信息&#xff0c;如LLaVA和Gemini&#xff0c;已经在包括图像字幕、视觉问题回答和图像检…

论文阅读:All-In-One Image Restoration for Unknown Corruption

发表时间&#xff1a;2022 cvpr 论文地址&#xff1a;https://openaccess.thecvf.com/content/CVPR2022/papers/Li_All-in-One_Image_Restoration_for_Unknown_Corruption_CVPR_2022_paper.pdf 项目地址&#xff1a;https://github.com/XLearning-SCU/2022-CVPR-AirNet 代码解读…

c++中, 直接写浮点数, 是float 还是 double?

如果直接一个浮点数, 那么他默认是float还是double呢? 测试用例 #include <iostream> using namespace std;int main() {auto x 0.2;float f 0.2;double d 0.2;cout << "x Size : " << sizeof(x) << " bytes" << endl…

vue28:组件化开发和根组件

简单写个点击事件 <template> <div class"app"><div class"box" click"fn"></div></div> </template><script> export default {//导出当前组件的配置项//里面可以提供 data methods computed wat…

AtCoder Beginner Contest 356 G. Freestyle(凸包+二分)

题目 思路来源 quality代码 题解 对n个泳姿点(ai,bi)建凸包&#xff0c;实际上是一个上凸壳&#xff0c; 对于询问(ci,di)来说&#xff0c;抽象画一下这个图&#xff0c;箭头方向表示询问向量 按x轴排增序&#xff0c;并且使得后面的y不小于前面的y&#xff0c;因为总可以多…

java asm使用切面

在Java中&#xff0c;使用ASM框架实现切面主要涉及到字节码操作和运行时动态代理。ASM是一个流行的Java字节码操作库&#xff0c;它允许开发者在编译时期或运行时期修改类和方法的行为。以下是使用ASM实现切面的方法&#xff1a; ### 一、引入依赖 首先&#xff0c;在你的项目中…

C++ Easyx案例实战:Cookie Maker工作室1.0V

前言 //制作属于自己的工作室&#xff01; 注&#xff1a;运行效果以及下载见Cookie Maker 工作室成立程序。 关于Cookie Maker工作室成立的信息&#xff0c;I am very happy&#xff08;唔……改不过来了&#xff09;。 OKOK&#xff0c;第一次用图形库写程序&#xff08;图形…

【Maxcompute】数据封装json、根据经纬度计算距离、根据证件号提取年龄段信息、判断是否在外包多边形内udf、udtf函数

1.梳理、总结经纬度处理在Maxcompute平台上的实战应用&#xff0c;如模型结果等封装json格式、根据经纬度计算距离udf、根据证件号提取年龄段信息、判断是否在外包多边形内udf、udtf、函数注册与使用。 2.欢迎批评指正&#xff0c;跪谢一键三连&#xff01; 文章目录 1.参考代码…

Java之数据库连接桥梁JDBC学习笔记

JDBC调用 Java与数据库的连接桥梁是JDBC&#xff08;Java Database Connectivity&#xff09;。JDBC是Java编程语言中用于连接和执行数据库操作的API&#xff08;应用程序编程接口&#xff09;。它提供了一种标准的方法&#xff0c;允许Java程序与各种数据库&#xff08;如MyS…

在开源处理器架构RISC-V中发现可远程利用的中危漏洞

在RISC-V SonicBOOM处理器设计中发现中度危险的漏洞 最近&#xff0c;西北工业大学的网络空间安全学院胡伟教授团队在RISC-V SonicBOOM处理器设计中发现了一个中度危险的漏洞。这个团队的研究人员发现了一个可远程利用的漏洞&#xff0c;该漏洞存在于开源处理器架构RISC-V中。…