数据库(mysql语句)循环语句

news2024/12/28 5:09:28

例题1:

20到50之间能被5除余1的所有自然数的和

EDECLARE @i int
DECLARE @s int
SET @s=0
SET @i=20
白WHILE @i <=50
BEGIN
IF(@i%5=1)
SET @s = @s + @i
SET @i=@i+1
END
PRINT'20到50之间能被5除余1的所有自然数的和是'+cast(@s as varchar(20))

 

例题2:

实现如下图

代码

DECLARE @i int
DECLARE @j int
DECLARE @str varchar(50)
SET @i = 1
WHILE @i<=5
BEGIN
SET @j = 1
SET @str=''
WHILE @j<11-@i*2
BEGIN
SET @str = @str +'"
SET @j = @j+1
END
SET @j= 0:
WHILE @j<2*@i-1
BEGIN
SET @str=@str+CAST( @i as CHAR(1))+''
SET @j = @j + 1
END
PRINT @str
SET @i=@i +1
END

 例题3:

代码:power表示power(i,j)-----i的j次方

DECLARE @i int
DECLARE @j int
DECLARE @temp int
DECLARE @str varchar(50)
SET @i = 1
WHILE @i<=5
BEGIN
SET @j= 1
SET @str =''
WHILE @j <= @i
BEGIN
SET @str = @str +''+ CAST( power( @i, @j ) AS VARCHAR(20))
SET @j=@j+1
END
PRINT @str
SET @i = @i + 1
END

例题4:

 实现

代码:

DECLARE @i INT
DECLARE @color VARCHAR(50)
SET @color ='红橙黄绿青蓝紫’
SET @i=0
WHILE @i < 7
BEGIN
PRINT SUBSTRING( @color, @i +1,7-@i)+SUBSTRING(@color,1,@i)
SET @i=@i+1
END

 注:substring是从1开始,第一个参数表示要截取的字符串,第二个i和第三个j表示从第i个开始截,截取j个,如:str=HELLO, substring(str,2,4),得到的结果为:ELLO

如果是sucstring(str,2):表示从第二个开始截,一直截到最后一个字符

例题5

实现

 代码:

注:

replicate的用法

replicate(’L‘,1)+'手机'   得到:L手机

第一个字符表示要重复的字母或字符串,第二个表示重复次数

reverse的用法:

reverse就是将字符串倒过来输出,如:一二三四五六七八九,操作后变为九八七六五四三二一

两个方法的主要思想:

该方法把每一行的字符拆成三部分看,例如:

一二三四五六七八九      九       九八七六五四三二一

方法1:

DECLARE @i INT
DECLARE @inwords VARCHAR (50)
DECLARE @outwords VARCHAR(50)
DECLARE @1en INT
SET @inwords ='一二三四五六七八九'
SET @1en=LEN(@inwords)
SET @i =0
WHILE @i<= @1en
BEGIN
PRINT SUBSTRING @inwords, 1,@1en-@i)
+REPLICATE(SUBSTRING (@inwords,@1en,1),2*@i+1 )
+REVERSE(SUBSTRING(@inwords ,1,@1en-@i))
SET @i = @i + 1
END

方法2:

DECLARE @i INT, @j INT, @k INT
DECLARE @inwords VARCHAR(50)
DECLARE @len INT
SET @inwords ='一二三四五六七八九'
SET @1en=LEN(@inwords)
SET @inwords =@inwords+'九'+REVERSE(@inwords)
SET @i= 0
SET @j = 9
SET @k= 3 
WHILE @i <= @1en
BEGIN
PRINT STUFF( @inwords, @j, @k, REPLICATE('九',@k))
SET @i = @i + 1
SET @j=@j-1
SET @k=@k+2
END

stuff字符串函数:

STUFF字符串函数是将字符串插入到另一个字符串中。它会删除开始位置第一个字符串中的指定长度的字符,然后将第二个字符串插入到开始位置的第一个字符串中,语法如下。

STUFF(<character_expression>,<开始>,<长度>,<character_expression>)

<character_expression>参数是给定的字符串数据,可以是字符或二进制数据的常量,变量或列。<start>参数是一个整数值,指定开始删除和插入的位置,可以是BIGINT类型。如果<开始>或<长度>参数为负数,则返回NULL字符串。如果<start>参数比第一个<character_expression>长,则返回一个NULL字符串。 <length>参数可以是BIGINT类型,它是一个整数,指定要删除的字符数。如果<length>比第一个<character_expression>长,则删除发生到最后一个<character_expression>中的最后一个字符。

DECLARE @FullName       VARCHAR(100)
DECLARE @Alias          VARCHAR(20)

SET @FullName = 'Jeffcky Wang'
SET @Alias = ' "Superman" '

SELECT STUFF(@FullName, CHARINDEX(' ', @FullName), 1, @Alias) AS [FullName] 

charindex:表示返回指定字符串的位置

如:

1.简单用法

select charindex('test','this Test is Test')

查询结果:
在这里插入图片描述

2.增加开始位置

select charindex('test','this Test is Test',7)

查询结果:
在这里插入图片描述

3.大小写敏感

select charindex('test','this Test is Test'COLLATE Latin1_General_CS_AS)

查询结果:
在这里插入图片描述
返回结果为0???,不要怀疑你的眼睛,因为大小写敏感,找不到test所以返回的就是0,默认情况下, SQL SERVER是大小不敏感的,所以我们简单示例中返回结果不为0,但是有些时候我们需要特意去区分大小写,因此专门SQL SERVE提供了特殊的关键字用于查询时区分大小写,其中CSCase-Sensitve的缩写。

4.大小写不敏感

select charindex('Test','this Test is Test'COLLATE Latin1_General_CI_AS)

查询结果:
在这里插入图片描述
我们也可以这样说明是大小写不敏感,其中CICase-InSensitve的缩写,即大小写不敏感,当然我们没必要多此一举。

 参考:http://t.csdn.cn/Um24k​​​​​​

如果对sql内置函数不熟:http://t.csdn.cn/exzcN

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

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

相关文章

设计模式之门面模式(Facade Pattern 外观模式)

一、模式定义 门面模式(Facade Pattern)&#xff1a;外部与一个子系统的通信必须通过一个统一的外观对象进行&#xff0c;为子系统中的一组接口提供一个一致的界面&#xff0c;外观模式定义了一个高层接口&#xff0c;这个接口使得这一子系统更加容易使用。门面模式又称为外观…

中国南方Oracle用户组沙龙活动:大环境下的Oracle数据库的机遇与挑战

2023年03月12日(周日)在杭州索菲特西湖大酒店 (浙江省杭州市上城区西湖大道333 号)&#xff0c;中国南方Oracle用户组创始人之一&#xff1a;周亮&#xff08;zhou liang&#xff09;组织举办了主题为《大环境下的Oracle数据库的机遇与挑战》活动&#xff0c;大约有50名左右的人…

YMatrix 5.0 故障自动转移功能新实现,运维更方便!

前言 分布式数据库一般都实现了数据多副本的存储以保证数据的高可用性。在多副本存储的基础上&#xff0c;通过切换活跃的存储副本来实现故障转移&#xff0c;是常见的做法。 YMatrix 5.0 实现了在数据库集群所有数据分片上的故障自动转移&#xff0c;完全实现了数据库集群的…

一文带你深入了解分布式数据的复制原理!!

在分布式数据系统中&#xff0c;复制是一种重要的能力。简单来说&#xff0c;复制就是将数据的副本存储在多个位置&#xff0c;通常是在不同的服务器或节点上。这样做有几个关键的优点&#xff1a; 使得数据与用户在地理上接近&#xff08;从而减少延迟&#xff09;&#xff0…

渗透测试--3.1嗅探欺骗攻击

目录 1.中间人攻击 2. 社会工程学攻击 SET使用实例——建立克隆钓鱼网站收集目标凭证 SET工具集之木马欺骗实战反弹链接 后渗透阶段 钓鱼邮件 总结 1.中间人攻击 中间人攻击&#xff08;Man-in-the-middle attack&#xff0c;简称MITM&#xff09;是一种常见的网络攻击…

一文带你完整了解数据的编码!!

数据编码是将数据转换为计算机可读取和处理的二进制格式的过程。在数据存储中&#xff0c;正确的数据编码非常重要&#xff0c;因为它能够保证数据的完整性、可靠性和可读性。 数据编码可以确保数据在存储过程中不会发生错误。通过使用适当的数据编码规则&#xff0c;可以防止…

三十二、自定义镜像

1 、Docker镜像的原理 Docker镜像本质是什么? Docker中一个centos镜像为什么只有200MB&#xff0c;而一个centos操作系统的iso文件要几个G? Docker中一个tomcat镜像为什么有500MB&#xff0c;而一个tomcat安装包只有10多MB? 操作系统组成部分: 计算机组成原理 进程调度子…

OPPO 关停“造芯”业务 ZEKU:一场大胆的尝试的结束

前言 近期&#xff0c;OPPO 关停了其“造芯”业务 ZEKU&#xff0c;结束了其自主研发处理器的尝试。本文将对这一事件进行探讨&#xff0c;分析其背后的原因及其对整个行业的影响。 1. ZEKU的成立与使命 在2019年&#xff0c;OPPO旗下的ZEKU研究所成立&#xff0c;标志着OPP…

Redis缓存穿透、缓存雪崩和缓存击穿

缓存穿透 缓存穿透&#xff0c;是指查询一个缓存和数据库中都没有的数据。正常的使用缓存流程大致是&#xff0c;数据查询先进行缓存查询&#xff0c;如果key不存在或者key已经过期&#xff0c;再对数据库进行查询&#xff0c;并把查询到的对象&#xff0c;放进缓存。如果数据库…

Centos和Windows之间通过主机名实现相互访问

一、业务需求 在内网环境中,我们想直接通过特定的主机名称去访问我们的服务器,而不用去记忆服务器的IP地址,且不想通过nginx等代理工具或域名配置内容来操作。 二、分析 通常我们可以直接在浏览器中输入【localhost】后按下回车键后就可以访问我们的主机80端口的内容了;那…

计算机网络大作业(Wireshark抓包分析)

实验要求 wireshark的深入学习与掌握&#xff0c;如过滤器的使用&#xff0c;归纳方法通过实验阐述ARP的工作原理利用实验结果分析 ICMP 协议的报文结构字段定义基于实验数据深入分析 TCP 协议的连接过程原理&#xff0c;报文的分片等功能从校园网发起向外网中某 Web 服务器的…

基于正点原子电机实验的pid调试助手代码解析(速度环控制)

这里写目录标题 下位机与PID调试助手传输的原理代码讲解(基于正点原子)解析数据接受和数据发送的底层函数数据接受数据帧格式环形数组以及怎么找到它的帧头位置crc校验 数据发送数据上传函数 通过前两节文章&#xff0c;我已经了解了基本的pid算法&#xff0c;现在在完成了电机…

MatrixGate 5.0 性能再升级,加载速度提升三倍!

前言 数据的加载速度在数据处理和分析领域一直是一个挑战&#xff0c;为应对这一挑战&#xff0c;YMatrix 数据库开发了 mxgate 高速数据加载工具。最近&#xff0c;随着 YMatrix 5.0 的 GA&#xff0c;新版 mxgate 与上一版本&#xff08;4.8.1&#xff09;相比&#xff0c;速…

Linux 虚拟机 磁盘扩容

概述 在单台虚拟机上部署了过多服务&#xff0c;导致磁盘使用过度达到98%。 现在扩容提高磁盘容量&#xff0c;增加10G。 现象 df -h df -ih du -s具体步骤 VMware 扩容 关闭虚拟机的情况下执行&#xff0c;类似于生产环境下需要关闭服务器&#xff0c;从而添加硬盘等相关操作…

Liunx基础命令 - rm删除命令

rm命令 – 删除文件或目录 rm命令来自英文单词“remove”的缩写&#xff0c;中文译为“消除”&#xff0c;其功能是用于删除文件或目录&#xff0c;一次可以删除多个文件&#xff0c;或递归删除目录及其内的所有子文件。 rm也是一个很危险的命令&#xff0c;使用的时候要特别…

从BinDiff到0day 在IE中利用CVE-2019-1208

前言 如上所述&#xff0c;CVE-2019-1208是UAF漏洞&#xff0c;这类安全漏洞可以破坏有效数据、引发进程crash、并且可以精心利用最终导致任意代码执行。而对于本文介绍的CVE-2019-1208而言&#xff0c;成功利用此漏洞的攻击者可以获得系统当前用户权限。如果当前用户具有admi…

理解Java虚拟机——JVM

目录 一、初识JVM 二、JVM执行流程 三、内存区域划分&#xff08;JVM运行时数据区&#xff09; 3.1 本地方法栈&#xff08;线程私有&#xff09; 3.2 程序计数器&#xff08;线程私有&#xff0c;无并发问题&#xff09; 3.3 JVM虚拟机栈&#xff08;线程私有&#xff0…

最全的分布式事务详情,它来啰~

我们首先得理解什么是分布式事务呢&#xff1f;分布式事务是指在分布式系统中&#xff0c;涉及多个计算机或服务器的操作序列&#xff0c;这些操作需要满足一致性和可靠性的要求。每个操作要么全部成功执行&#xff0c;要么全部回滚&#xff0c;以保持数据的一致性和完整性。 …

嵌入式通信协议【Modbus】Modbus TCP的帧格式

一、请求帧格式 Client request:例&#xff1a; 19 B2 00 00 00 06 06 03 00 27 00 02 1、头字节 上面是modbus客户端发出的报文内容&#xff0c;为modbus tcp/ip协议格式&#xff0c;其前面的六个字节为头字节( header handle)&#xff1b; 19 B2 00 00 00 06 19 B2 00 00…

3D点云之语义分割(相关官方示例介绍)

之前在博客中提到&#xff0c;会考虑用深度学习来对3D点云进行处理&#xff0c;接下来迈出脚步&#xff0c;先整几个例子来熟悉它。例子原型来源于官网&#xff0c;博主在其基础上做了一些代码修改。 一. 例子参考 1. Keras中的资源 Code examples 2.openvinotoolkit open_…