暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

“G”术时刻:GBase 8s数据库记录类型的原理及应用

原创 GBASE数据库 2025-05-09
138


在数据库的PL/SQL编程模式下,记录类型是一种非常重要的数据结构,它允许开发者定义包含多个字段的复合数据类型。这种类型的数据结构在处理复杂数据时非常灵活,能够有效地提高代码的可读性和可维护性。


本文将以GBase 8s数据库为例,讨论记录类型的特点、使用场景以及实际应用,来帮助广大开发者和数据库使用者更好地理解和运用这一功能。


要使用PL/SQL语法,需要显示设置环境变量  SQLMODE为ORACLE 。默认情况下,GBase 8s的SQLMODE为GBASE,此时不支持PL/SQL语法。因此,在开始编写PL/SQL代码之前,请确保已经正确设置了环境变量。


语    法



创建记录类型


  • 记录类型可以在匿名块中定义,仅在块中生效;

  • 记录类型可以在包中定义公有类型,全局生效;

  • 不可以在外部create type。


创建记录变量的方式


  • 定义一个RECORD类型,然后声明该类型的变量;

  • 使用%ROWTYPE声明一个记录变量,该变量表示数据库表或视图的完整或部分行;

  • 使用%TYPE声明与之前声明的记录变量类型相同的记录变量。


记录类型变量的初始值


  • 对于RECORD类型的记录变量,每个字段的初始值为NULL,除非您在定义类型时为其指定不同的初始值;


  • 对于用%ROWTYPE或%TYPE声明的记录变量,每个字段的初始值为NULL。该变量不继承引用项的初始值。


记录类型的应用


1)声明始终代表全行的记录变量。


    variable_name 、table_or_view_name%ROWTYPE;


    注:表中包含虚拟列时,无法直接将记录变量值插入到表中,需要将不包含虚拟列的单个字段插入。表中包含不可见列时,%rowtype获得的列不包含该列。


    2)声明始终代表部分行的记录变量。


      variable_name cursor%ROWTYPE;


      3)变量赋值:同一类型,不同变量间可以赋值。


        name1:=name2;


        4)%rowtype和record变量可以相互赋值。


        5)使用select into将行分配给记录变量。


          SELECT select_list INTO record_variable_name FROM table_or_view_name;


          6)使用fetch将行分配给记录变量。

            FETCH cursor INTO record_variable_name;


            7)使用SQL语句返回PLSQL记录类型变量的值。


              SELECT select_list INTO record_variable_name FROM table_or_view_name;


              8)将NULL分配给记录变量,会将null分配给变量的每个field。



              场景举例



              运行结果



              GBase 8s的记录类型为开发者提供了一种灵活的数据结构,能够有效地简化复杂数据的处理过程。在实际开发中,合理运用记录类型可以提高代码的可读性和可维护性,进一步提升开发效率。

              直播预约:GBase数据库在轨交核心领域的应用




              GBase 8s作为南大通用自主研发的企业级国产交易型数据库,成熟稳定并达到国标第四级安全标准,支持共享存储集群、两地三中心高可用部署,为金融、电信、能源、交通等行业的关键核心业务系统提供了稳定的数据服务。

              在轨交领域,GBase 8s上线深圳、重庆、西安、成都、郑州、杭州、沈阳、济南等全国27座城市的70+条线路,支持了轨交领域AFC自动售检票系统、清分中心、多线路中心、互联网票务系统、综合监控系统、运营指挥中心等核心业务系统,为市民提供了高效、便捷、稳定的出行服务。

              今晚19:30,南大通用能源交通部技术总监王顶卓将在直播间分享《GBASE南大通用助力轨道交通数据库国产化选型》的主题演讲,在核心业务场景中感受GBase 8s的技术特性,直播间更有精美礼品抽送,欢迎大家预约观看~




              本期供稿 | GBase 8s产品经营部

              本期编辑 | Suse

              内容审核 | 生态发展部



              最后修改时间:2025-05-09 16:40:51
              文章转载自GBASE数据库,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

              评论