0
点赞
收藏
分享

微信扫一扫

第五十四章 SQL函数 EXP

kmoon_b426 2022-02-15 阅读 30

文章目录

第五十四章 SQL函数 EXP

返回数字的指数(自然对数的倒数)的标量数值函数。

大纲

{fn EXP(expression)}

参数

  • expression - 对数指数,数值表达式。

EXP返回NUMERICDOUBLE数据类型。如果表达式的数据类型为DOUBLE,则EXP返回DOUBLE;否则返回NUMERIC

描述

Exp是指数函数e n,其中e是常数2.718281828。因此,要返回e的值,可以指定{fn exp(1)}Exp是自然对数函数log的逆函数。

EXP返回一个精度为36、小数位数为18的值。如果传递的值为NULL,则EXP返回NULL

EXP只能用作ODBC标量函数(使用花括号语法)。

示例

下面的示例返回常量e:

SELECT {fn EXP(1)} AS e_constant

2.718281828459045235

下面的嵌入式SQL示例返回整数010的指数值:

ClassMethod Exp()
{
	s a = 0
	while a < 11 {
	&sql(SELECT {fn EXP(:a)} INTO :b)
	if SQLCODE'=0 {
		w !,"错误代码 ",SQLCODE
		q 
	} else {
		w !,"指数 ",a," = ",b
		s a=a+1 }
	}
}
DHC-APP>d ##class(PHA.TEST.SQLCommand).Exp()
 
指数 0 = 1
指数 1 = 2.718281828459045235
指数 2 = 7.389056098930650228
指数 3 = 20.08553692318766774
指数 4 = 54.59815003314423907
指数 5 = 148.4131591025766034
指数 6 = 403.4287934927351225
指数 7 = 1096.633158428458599
指数 8 = 2980.957987041728276
指数 9 = 8103.083927575384008
指数 10 = 22026.46579480671652

下面的嵌入式SQL示例演示了explog相反:

ClassMethod Exp1()
{
	s x=7
	&sql(SELECT {fn EXP(:x)} AS Exp,
			{fn LOG(:x)} AS Log,
			{fn EXP({fn LOG(:x)})} AS ExpOfLog
		INTO :a,:b,:c)
	if SQLCODE'=0 {
		w !,"Error code ",SQLCODE
		q 
	} else {
		w "Exponential of ",x," = ",a,!
		w "Natural log of ",x," = ",b,!
		w "Exp of Log of  ",x," = ",c
	}
}
DHC-APP> d ##class(PHA.TEST.SQLCommand).Exp1()
Exponential of 7 = 1096.633158428458599
Natural log of 7 = 1.945910149055313306
Exp of Log of  7 = 7.000000000000000004

注意,在第三个函数中,调用数字输入和计算的返回值之间的小差异。下一个示例显示如何处理这种计算差异。

下面的嵌入式SQL示例显示了整数1到10的logexp函数之间的关系:

ClassMethod Exp2()
{
	s a = 1
	while a < 11 {
	&sql(SELECT {fn LOG(:a)} INTO :b)
	if SQLCODE '= 0 {
		w !,"Error code ",SQLCODE
		q 
	} else {
		w !,"Logarithm of ",a," = ",b }
		&sql(SELECT ROUND({fn EXP(:b)},12) INTO :c)
		if SQLCODE '= 0 {
			w !,"Error code ",SQLCODE 
		} else {
			w !,"Exponential of log ",b," = ",c 
			s a = a + 1 
		}
	}
}
DHC-APP>d ##class(PHA.TEST.SQLCommand).Exp2()
 
Logarithm of 1 = 0
Exponential of log 0 = 1
Logarithm of 2 = .6931471805599453089
Exponential of log .6931471805599453089 = 2
Logarithm of 3 = 1.098612288668109691
Exponential of log 1.098612288668109691 = 3
Logarithm of 4 = 1.386294361119890618
Exponential of log 1.386294361119890618 = 4
Logarithm of 5 = 1.609437912434100375
Exponential of log 1.609437912434100375 = 5
Logarithm of 6 = 1.791759469228055002
Exponential of log 1.791759469228055002 = 6
Logarithm of 7 = 1.945910149055313306
Exponential of log 1.945910149055313306 = 7
Logarithm of 8 = 2.079441541679835929
Exponential of log 2.079441541679835929 = 8
Logarithm of 9 = 2.197224577336219384
Exponential of log 2.197224577336219384 = 9
Logarithm of 10 = 2.302585092994045684
Exponential of log 2.302585092994045684 = 10

请注意,这里需要ROUND函数来校正系统计算限制导致的非常小的差异。在上面的示例中,为此目的将舍入任意设置为12位十进制数字。

举报

相关推荐

0 条评论