SQL中的指示变量及数组变量
创始人
2024-07-13 11:20:48
0

在SQL数据库中有多种变量,下面就将为您介绍SQL中的指示变量及数组变量,供您参考,希望对您学习SQL中的变量能够有所帮助。

1.指示变量

实际上也是一类SQL变量,它被用来管理与其相关联的宿主变量(即在SQL语句中充当输入或输出的变量)。每一个宿主变量都可定义一个指示器变量,主要用于处理空值(NULL)
指示器变量的说明基本同一般SQL变量一样, 但必须定义成2字节的整型,如SHORT、INT。在SQL语句中引用时,其前也应加“:”(冒号),而且必须附在其相关联的宿主变量之后,在C语句中,可独立使用。当指示器变量为-1时,表示空值。例如:

EXEC SQL BEGIN DECLARE SECTION ;

    INT dept_number;

    SHORT ind_num;

    CHAR emp_name;

    EXEC SQL END DECLARE SECTION ;

    Scanf(“90d %s”, & dept- number , dept – name );

    If (dept_number ==0)

           Ind_num = -1;

    Else

           Ind_num = 0;

    EXEC SQL INSERT INTO DEPT (DEPTNO, DNAME)

    VALUES(:dept_number:ind_num , :dept_name);

  其中ind – num是dept – number 的指示器变量。当输入的dept_number 值是0时, 则向DEPT 表的DEPTNO列插入空值。#p#

2.数组SQL变量

在SQL语句中引用数组时,只需写数组名(名字前加冒号),不需写下标,在C语句中用法如同C语言的数组变量。使用数组可大大降低网络传输开销。如要向一表插入100行数据,如果没有数组,就要重复100次, 而引用后,只须执行一次insert语句、便可一次性插入。例如:

   EXEC SQL BEGIN DECLARE SECTION;

   Int emp_number[100];

   Char emp_name[100][15];

   Float salary[100],commission[100];

   Int dept_number;

   EXEC SQL END DECLARE SECTION;

   ….

   EXEC SQL SELECT EMPNO,ENAME,SAL,COMM

   INTO :emp_number,:emp_name,:salary,:commission

   FROM EMP

   WHERE DEPTNO=:dept_number;

   在使用数组时,应注意以下几点;

1)不支持指针数组

   2)只支持一维数组, 而 emp-name [100][15]视为一维字符串#p#

   3)数组***维数为32767,超出会报“paramter out of range”错 误

   4) 在一条SQL语句中引用多个数组时,这些数组维数应相同

   5)在VALUES , SET, INTO 或WHERE子名中, 不允许把简单SQL变量与数组SQL变量混用

   6)不能在DELARE部分初始化数组

   例如:下面的引用是非法的

   EXEC SQL BEGIN DECLARE SECTION;

   Int dept_num [3] = {10,20,30};

   EXEC SQL END DECLARE SECTION ;

   EXEC SQL SELECT EMPNO, ENAME , SAL

   INTO : emp_num [ i ], : emp_name [ i ], : salarg [ i ]

   FROM EMP

7)在UPDATE或DELETE语句中,不允许把数组与CURRENT OF字句一起使用
 

 

 

【编辑推荐】

SQL中系统变量的应用实例

详解SQL Server分布式查询

用SQL游标遍历循环数据的方法

sql中while语句多层循环实例

For循环中执行SQL查询的讨论

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...