sql 存储过程中何时使用declare声明变量[通俗易懂]

sql 存储过程中何时使用declare声明变量[通俗易懂]这个问题我从百度第二页才找得到答案,就从别人的答案自己仔细研究懂了,顺便整理了过来。原文链接:https://zhidao.baidu.com/question/245490659799230284.html如果把存储过程看作是批处理语句就好理解多了存储过程只不过是一个带着名称的SQL批处理语句,如果在整个过程中需要变量时就是可以声明,但该变量声明后只能存活在批处理(存储过程)的…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

这个问题我从百度第二页才找得到答案,就从别人的答案自己仔细研究懂了,顺便整理了过来。
原文链接:https://zhidao.baidu.com/question/245490659799230284.html

如果把存储过程看作是批处理语句就好理解多了

存储过程只不过是一个带着名称的SQL批处理语句,如果在整个过程中需要变量时就是可以声明,但该变量声明后只能存活在批处理(存储过程)的运行中,运行完毕后就会消失,这种声明的格式就是:declare 变量名 类型

其中变量名为了与数据库中的列名相互区别,所以变量名有一个前置@符号,比如说:declare @count int

就是将变量@count声明为int类型的,以后可以使用变量@count作为整型变量使用。在这里可能有一些误解,有人认为@count是变量名,也有人认为count是变量名,而@只是一个符号,其实不管那一种理解对于声明变量上来说是不影响的,事实上应该来说@count被称为变量名较为合适些。

刚才说过,该变量声明后只存活于批处理或是存储过程的运行中而已,也就是说是一个局部变量,其实在SQL中还有一种变量是全局变量的,他们以@@开头,但目前的SQL中还不允许客户自己的声明全局变量,只是系统中存在的。比如查询系统版本,就可以使用select @@version的方式进行查看的。因为不能够声明,所以不与declare一块使用的情况。

其实在SQL中将变量一词演译的非常深,还有一类变量就是表名,列名,存储过程等名称,这些名称其实也算是数据库的全局变量的,只要表存在,那么表名一定会存在于master数据库中的一个表中,列名也是一样,这一类的变量有一个特殊,都是已经存在的object(对象),所以不须要进行声明,等于是建库或表时进行了声明,然后就可以了使用了,这种情况下的变量前边是没有@符号提示的。

所以一般情况下,我们只称@前置的为变量,没有前置的为数据库相关变量,而@@是系统变量不须声明。但只要是在使用@自定义的变量时,就必须选进行声明,而其他的则不须要

转载于:https://www.cnblogs.com/donelyorjune/p/11104981.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/171468.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月20日 下午10:00
下一篇 2022年8月20日 下午10:16


相关推荐

  • 如何使用 AI 生成一个 PPT?

    如何使用 AI 生成一个 PPT?

    2026年3月16日
    3
  • SSTI 学习

    SSTI 学习bugku 的 simplessti 打开题目看到需要上穿一个 flag 的参数打开原代码查看提示需要用到 flask 的模板注入 Flask 是一个基于 Python 的 Web 开发微框架 利用 get 的方式传参 flag config SECRET KEY 即得到 flag 在 Flask 项目中 我们会用到很多配置 Config Flask 的配置对象 config 是一个字典的子类 subclass 所以你可以把配置用键值对的方式存储进去 这是一个通用的处理接口 Flask 内置的配置 扩展提供的配置 你

    2026年3月26日
    2
  • rpc协议详解

    rpc协议详解RPC是一种远程过程调用的协议,使用这种协议向另一台计算机上的程序请求服务,不需要了解底层网络技术的协议。HTTP是一种超文本传输协议。是WWW浏览器和WWW服务器之间的应用层通讯协议。TCP协议:传输控制协议,是一种面向连接的、可靠的、基于字节流的传输层通信协议。https://mp.weixin.qq.com/s?src=11&timestamp=1611734678&ver=2853&signature=igsdPz20ZUht*1IskaU0LxnFKvD6tD.

    2022年5月19日
    94
  • 现代语音信号处理笔记 (一)

    现代语音信号处理笔记 (一)本系列笔记对胡航老师的现代语音信号处理这本书的语音处理部分进行总结,包含语音信号处理基础、语音信号分析、语音编码三部分。一开始以为三部分总结到一篇文章里就可以了,但写着写着发现事情并没有那么简单。。。因此还是老老实实的总结吧,扎实的基础最重要。语音信号处理基础语音信号的处理简称语音处理,是用数字信号处理技术对语音信号进行处理的一门学科。语音信号均采用数字方式进行处理,语音信号的数字…

    2022年5月26日
    44
  • sched://task scheduler_Task Scheduler

    sched://task scheduler_Task SchedulerSpringBoot自带的任务调度是如何实现的?@EnableScheduling@Scheduled注解在任务调度的实现中承担了怎样的角色?ScheduledAnnotationBeanPostProcessor是如何工作的?都参与了ApplicationContext生命周期的哪些环节?调度是通过TaskScheduler实现的,默认的TaskScheduler是怎么创建的?我们如何通过SchedulingConfigurer创建自己的TaskScheduler?

    2022年10月11日
    5
  • 基于POI实现Excel表的导入导出功能[通俗易懂]

    基于POI实现Excel表的导入导出功能[通俗易懂]对于批量数据的操作,在项目中引进Excel的导入和导出功能是个不错的选择。对于Excel表的结构,简单理解可以把它分成三部分(Sheet,Cell,Row),这三部分可以理解为excel表中的页,列,行。因此,我们想要获取到某一个单元的内容,可以通过获取该单元所在的页数、对应所在的行和对应的列数从而定位到该单位,继而便可执行操作从而获取其中的内容。本文在SSM环境下基于Java的POI实现对exc…

    2025年7月1日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号