前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL函数 %EXTERNAL

SQL函数 %EXTERNAL

作者头像
用户7741497
发布2022-04-02 13:42:09
2950
发布2022-04-02 13:42:09
举报
文章被收录于专栏:hml_知识记录hml_知识记录

SQL函数 %EXTERNAL

以显示格式返回表达式的格式转换函数。

大纲

代码语言:javascript
复制
%EXTERNAL(expression)

%EXTERNAL expression

参数

  • expression - 要转换的表达式。字段名、包含字段名的表达式或返回值为可转换数据类型(如DATE%LIST)的函数。不能是流字段。

描述

%EXTERNAL将表达式转换为显示格式,与当前选择模式(显示模式)无关。显示格式表示VARCHAR数据类型的数据,无论字段或数据类型LogicalToDisplay方法执行什么数据转换。

%EXTERNAL通常用于选择列表SELECT-ITEM。它可以在WHERE子句中使用,但不建议这样使用,因为使用%EXTERNAL会阻止在指定字段上使用索引。

应用%EXTERNAL会将列标题名称更改为诸如“Expression_1”之类的值;因此,通常需要指定列名别名,如以下示例所示。

%EXTERNAL是否转换日期取决于日期字段或函数返回的数据类型。%EXTERNAL转换CURDATECURRENT_DATECURTIMECURRENT_TIME值。它不转换CURRENT_TIMESTAMPGETDATEGETUTCDATENOW$HOROLOG值。

%EXTERNAL%List结构转换为显示格式时,显示的列表元素似乎由空格分隔。这个“空格”实际上是两个非显示字符CHAR(13)CHAR(10)

%EXTERNAL是一个SQL扩展。

无论当前选择模式是什么,要将表达式转换为LOGICAL格式,请使用%INTERNAL函数。 无论当前选择模式是什么,要将表达式转换为ODBC格式,请使用%ODBCOUT函数。

示例

下面的动态SQL示例以当前选择模式格式返回Date of Birth (DOB)数据值,并使用%EXTERNAL函数返回相同的数据。 为了演示的目的,在这个程序中,%SelectMode值在每次调用时都是随机确定的:

代码语言:javascript
复制
ClassMethod External()
{
    s tStatement = ##class(%SQL.Statement).%New()
    s tStatement.%SelectMode = $RANDOM(3)
    if tStatement.%SelectMode = 0 {w "Select mode LOGICAL",! }
    elseif tStatement.%SelectMode=1 {w "Select mode ODBC",! }
    elseif tStatement.%SelectMode=2 {w "Select mode DISPLAY",! }
    s myquery = 2
    s myquery(1) = "SELECT TOP 5 DOB,%EXTERNAL(DOB) AS ExtDOB "
    s myquery(2) = "FROM Sample.Person"
    s qStatus = tStatement.%Prepare(.myquery)
    s rset = tStatement.%Execute()
    d rset.%Display()
    w !,"End of data"
}
代码语言:javascript
复制
DHC-APP>d ##class(PHA.TEST.SQLCommand).External()
Select mode DISPLAY
DOB     ExtDOB
04/25/1990      04/25/1990
 
01/02/2014      01/02/2014
01/02/2014      01/02/2014
01/28/1978      01/28/1978
 
5 Rows(s) Affected
End of data

DHC-APP>d ##class(PHA.TEST.SQLCommand).External()
Select mode LOGICAL
DOB     ExtDOB
54536   04/25/1990
 
63189   01/02/2014
63189   01/02/2014
50066   01/28/1978
 
5 Rows(s) Affected
End of data
DHC-APP>d ##class(PHA.TEST.SQLCommand).External()
Select mode ODBC
DOB     ExtDOB
1990-04-25      04/25/1990
 
2014-01-02      01/02/2014
2014-01-02      01/02/2014
1978-01-28      01/28/1978
 
5 Rows(s) Affected
End of data

下面的例子展示了这个函数的两种语法形式; 它们在其他方面是相同的。 它们指定了%List字段的%EXTERNAL(显示格式)、%INTERNAL(逻辑格式)和%ODBCOUT (ODBC格式):

代码语言:javascript
复制
SELECT TOP 10 %EXTERNAL(FavoriteColors) AS ExtColors,
              %INTERNAL(FavoriteColors) AS IntColors,
              %ODBCOUT(FavoriteColors) AS ODBCColors
FROM Sample.Person

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • SQL函数 %EXTERNAL
  • 大纲
  • 参数
  • 描述
  • 示例
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档