当前位置: 首页 > news >正文

【Sql Server】随机查询一条表记录,并重重温回顾下存储过程的封装和使用

大家好,我是全栈小5,欢迎来到《小5讲堂》。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 前言
  • 随机查询语句
  • 存储过程
    • 基本概念
    • 基本结构
    • 基础例子
    • 存储过程封装
  • 文章推荐

前言

温故而知新,最近在写sql查询语句,需求是随机查询表的其中一条记录。
基于这个查询,顺便把数据库自定义函数、存储过程这个两个知识点重温固定下。
因此,本篇文章将在随机查询一条表记录的基础上,把sql语句封装到存储过程里。

随机查询语句

要在SQL Server中随机生成一条记录,可以使用ORDER BY NEWID()来随机排序结果集,并使用TOP 1来限制结果集返回一条记录。
例如:

select top 1 * 
from(select 1 as id,'张三11' as nameValue union all select 2 as id,'张三22' as name union all select 3 as id,'张三33' as nameValue union all select 4 as id,'张三44' as name union allselect 5 as id,'张三55' as nameValue union all select 6 as id,'张三66' as name union allselect 7 as id,'张三77' as nameValue union all select 8 as id,'张三88' as name
) a
order by newid()select 1 as id,'张三11' as nameValue union all select 2 as id,'张三22' as name union all 
select 3 as id,'张三33' as nameValue union all select 4 as id,'张三44' as name union all
select 5 as id,'张三55' as nameValue union all select 6 as id,'张三66' as name union all
select 7 as id,'张三77' as nameValue union all select 8 as id,'张三88' as name

在这里插入图片描述

存储过程

基本概念

在 SQL Server 中,存储过程是一组预编译的 SQL 语句和逻辑,存储在数据库服务器上以便重复使用。
它们类似于应用程序中的函数,可以接受参数并执行一系列的 SQL 语句,然后返回结果或执行特定的操作。
存储过程可以帮助提高性能、安全性和可维护性,同时减少网络流量。
存储过程通常用于执行复杂的数据操作、事务控制、权限控制等。

基本结构

CREATE PROCEDURE [schema_name.]procedure_name@parameter1 datatype,@parameter2 datatype
AS
BEGIN-- 存储过程逻辑
END;
  • schema_name(可选):存储过程所属的模式。
  • procedure_name:存储过程的名称。
  • @parameter1, @parameter2:存储过程的参数列表,包括参数名和数据类型。
  • AS:指示存储过程逻辑的开始。
  • 存储过程逻辑:存储过程内部包含一系列 SQL 语句和控制流程,用于执行特定的操作或计算。
  • END:指示存储过程逻辑的结束。
    存储过程可以包含各种 SQL 语句、条件控制、循环等逻辑,以及事务处理和错误处理代码。创建存储过程后,可以通过调用存储过程的名称并传递相应的参数来执行它。

基础例子

下面是一个简单的 SQL Server 存储过程的示例,该存储过程接受一个参数 @employee_id,并返回该员工的姓名和工资信息:

CREATE PROCEDURE GetEmployeeInfo@employee_id INT
AS
BEGINSELECT EmployeeName, SalaryFROM EmployeesWHERE EmployeeID = @employee_id;
END;

在这个示例中:

  • 存储过程名为 GetEmployeeInfo。
  • 参数 @employee_id 的数据类型为 INT。
  • 存储过程的逻辑部分使用了简单的 SELECT 查询语句,根据提供的 @employee_id 查询员工的姓名和工资信息。
  • END 结束存储过程的逻辑部分。
    要执行这个存储过程,可以使用如下的 SQL 语句:
EXEC GetEmployeeInfo @employee_id = 12345;

其中 12345 是要查询的员工的 ID。

存储过程封装

-- 创建存储过程
create procedure getDataPro@id int
as
beginselect top 1 *from(select 1 as id,'张三11' as nameValue union all select 2 as id,'张三22' as name union all select 3 as id,'张三33' as nameValue union all select 4 as id,'张三44' as name union allselect 5 as id,'张三55' as nameValue union all select 6 as id,'张三66' as name union allselect 7 as id,'张三77' as nameValue union all select 8 as id,'张三88' as name) awhere id=1order by newid()
end-- 执行存储过程
exec getDataPro 8

在这里插入图片描述

文章推荐

【Sql Server】随机查询一条表记录,并重重温回顾下自定义函数的封装和使用

【Sql Server】锁表如何解锁,模拟会话事务方式锁定一个表然后进行解锁

【Sql Server】通过Sql语句批量处理数据,使用变量且遍历数据进行逻辑处理

【新星计划回顾】第六篇学习计划-通过自定义函数和存储过程模拟MD5数据

【新星计划回顾】第四篇学习计划-自定义函数、存储过程、随机值知识点

【Sql Server】Update中的From语句,以及常见更新操作方式

【Sql server】假设有三个字段a,b,c 以a和b分组,如何查询a和b唯一,但是c不同的记录

【Sql Server】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Facebook开户 | Facebook A/B测试:优化社媒广告效果的关键
  • MQ本地消息事务表
  • 二进制安装Kubernetes(k8s)v1.30.1
  • STM32启动过程分析
  • 2024.05.27【读书笔记】丨生物信息学与功能基因组学(第八章 蛋白质分析与蛋白组学 下)【AI测试版】
  • linux下cp和mv命令显示进度条
  • 电脑卸载linux安装windows后每次开机都出现grub
  • 腾讯云COS上传文件出现的问题
  • 【Python爬虫】案例_百度贴吧
  • 埃文科技携数据要素产品亮相第七届数字中国建设峰会
  • 前端面试题日常练-day38 【面试题】
  • Java---Cloneable接口---浅克隆和深克隆
  • 深度学习-序列模型
  • GoldenEye-v1(vulnhub)靶机练习实践报告
  • windows11 system进程CPU占比过高解决方案
  • [LeetCode] Wiggle Sort
  • 07.Android之多媒体问题
  • echarts的各种常用效果展示
  • Github访问慢解决办法
  • javascript从右向左截取指定位数字符的3种方法
  • Java-详解HashMap
  • Java新版本的开发已正式进入轨道,版本号18.3
  • JS数组方法汇总
  • spring学习第二天
  • tweak 支持第三方库
  • Webpack入门之遇到的那些坑,系列示例Demo
  • 基于HAProxy的高性能缓存服务器nuster
  • 前端技术周刊 2019-01-14:客户端存储
  • 巧用 TypeScript (一)
  • 小程序开发中的那些坑
  • 一起来学SpringBoot | 第三篇:SpringBoot日志配置
  • gunicorn工作原理
  • 阿里云IoT边缘计算助力企业零改造实现远程运维 ...
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • #include到底该写在哪
  • #QT(TCP网络编程-服务端)
  • $.each()与$(selector).each()
  • (¥1011)-(一千零一拾一元整)输出
  • (4)logging(日志模块)
  • (52)只出现一次的数字III
  • (iPhone/iPad开发)在UIWebView中自定义菜单栏
  • (ISPRS,2021)具有遥感知识图谱的鲁棒深度对齐网络用于零样本和广义零样本遥感图像场景分类
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (附源码)ssm码农论坛 毕业设计 231126
  • (附源码)计算机毕业设计SSM教师教学质量评价系统
  • (论文阅读11/100)Fast R-CNN
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (十六)串口UART
  • (一)kafka实战——kafka源码编译启动
  • (一)u-boot-nand.bin的下载
  • .gitignore不生效的解决方案
  • .Net 8.0 新的变化
  • .NET CF命令行调试器MDbg入门(四) Attaching to Processes
  • .NET Framework与.NET Framework SDK有什么不同?
  • .NET Standard、.NET Framework 、.NET Core三者的关系与区别?