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

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

大家好,我是,欢迎来到《小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 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 ) 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 BEGIN SELECT EmployeeName, Salary FROM Employees WHERE 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 begin 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 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 ) a where id=1 order 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】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

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

http://www.jsqmd.com/news/452108/

相关文章:

  • 突破内容访问限制:开源浏览器扩展工具的技术实现与应用指南
  • BGE Reranker-v2-m3模型参数详解:568M参数配置与调优指南
  • 链表实战指南:从基础操作到高效应用(手把手教学)
  • ResNet18助力IoT设备:轻量级图像识别边缘部署方案
  • SUPER COLORIZER社区作品精选:全球创作者利用AI上色工具完成的精彩项目合集
  • 革新性英雄联盟界面定制工具:LeaguePrank安全使用指南
  • SketchUp STL插件:连接数字设计与3D打印的桥梁
  • all-MiniLM-L6-v2一键部署:5分钟搭建文本相似度计算服务
  • JetBrains IDE评估期重置完全指南:从问题诊断到价值延伸
  • Golang pprof实战:从线上内存泄漏到精准性能调优
  • 人工智能基础:谓词逻辑与知识表示实战解析
  • Google SRE实战:如何通过SLI、SLO与Error Budget构建高可用服务
  • Keil5嵌入式开发辅助:利用StructBERT分析调试日志与错误代码的关联性
  • 运算放大器的核心原理与典型电路设计实战
  • Qwen-Image-2512 Linux命令可视化:常用操作图解生成
  • 电力电子工程师必备:从SiC器件到数字孪生的完整工具链指南(附学习路径)
  • 4步高效优化:让低配电脑流畅运行ComfyUI的实战指南
  • Nvidia Jetson Orin NX(三)深度学习环境搭建实战
  • Qwen3-ASR-0.6B多语言识别实测:粤语、四川话、英语都能准确转写
  • Axure中继器实战:5分钟搞定动态柱状图(含自动缩放坐标轴技巧)
  • Qwen3-ASR-1.7B惊艳效果:方言混合(粤语+潮汕话)对话的语种细粒度识别
  • AgentCPM深度研报助手集成实战:与Dify平台构建AI工作流
  • nlp_gte_sentence-embedding_chinese-large处理多模态数据的潜力展示
  • 通义千问3-VL-Reranker-8B部署避坑指南:常见问题解决
  • OpenGL纹理优化实战:高效更新与局部刷新技巧
  • iVX、CodeWave与OneCode三大全栈低代码平台深度评测:谁更适合你的开发需求?
  • fnOS 飞牛私有云 NAS 上快速搭建 DeepSeek-R1 本地 AI 助手并配置安全外网访问
  • 手把手教你部署通义千问2.5-7B:免费商用,小白也能快速上手
  • OpenHarmony 软总线Lite:从被动发现到会话建立的源码全景解析
  • Keil5工程管理思维应用于CasRel模型实验项目管理