oracle数据库怎样查询用变量表示的字段名

oracle数据库怎样查询用变量表示的字段名,第1张

我的做法是:

asql是静态的,一个语句无法实现多种功能。需要一个动态变化的语句。

bpl/sql可以生成动态语句,但是无法直接select 出结果。

如:

create or replace procedure selectx

( v_field_nam in varchar2

)

is

begin

execute immediate 'select '|| v_field_nam ||' from dual ';

end selectx;

/

c利用'&' 的值替换功能,也可以实现你要的效果,

例如:

--1建立测试表:

create table t_mytable

(

c1

number

,c2

number

);

--2插入样本数据:

insert into t_mytable

select 1 , 2 from dual;

commit;

insert into t_mytable

select 3 , 4 from dual;

commit;

pzw> select from t_mytable;

1

2

3

4

--带输入参数的sql语句:

pzw> select c&num from t_mytable;

Enter value for num: 1

old

1: select c&num from t_mytable

new

1: select c1 from t_mytable

1

3

2 rows selected

pzw> select c&num from t_mytable;

Enter value for num: 2

old

1: select c&num from t_mytable

new

1: select c2 from t_mytable

2

4

2 rows selected

什么是变量

变量是一种使用方便的占位符,用于引用计算机内存地址,该地址可以存储 Script 运行时可更改的程序信息。例如,可以创建一个名为 ClickCount 的变量来存储用户单击 Web 页面上某个对象的次数。使用变量并不需要了解变量在计算机内存中的地址,只要通过变量名引用变量就可以查看或更改变量的值。在 VBScript 中只有一个基本数据类型,即 Variant,因此所有变量的数据类型都是 Variant。

声明变量

声明变量的一种方式是使用 Dim 语句、Public 语句和 Private 语句在 Script 中显式声明变量。例如:

Dim DegreesFahrenheit

声明多个变量时,使用逗号分隔变量。例如:

Dim Top, Bottom, Left, Right

另一种方式是通过直接在 Script 中使用变量名这一简单方式隐式声明变量。这通常不是一个好习惯,因为这样有时会由于变量名被拼错而导致在运行 Script 时出现意外的结果。因此,最好使用 Option Explicit 语句显式声明所有变量,并将其作为 Script 的第一条语句。

命名规则

变量命名必须遵循 VBScript 的标准命名规则。变量命名必须遵循:

第一个字符必须是字母。

不能包含嵌入的句点。

长度不能超过 255 个字符。

在被声明的作用域内必须唯一。

变量的作用域与存活期

变量的作用域由声明它的位置决定。如果在过程中声明变量,则只有该过程中的代码可以访问或更改变量值,此时变量具有局部作用域并被称为过程级变量。如果在过程之外声明变量,则该变量可以被 Script 中所有过程所识别,称为 Script 级变量,具有 Script 级作用域。

变量存在的时间称为存活期。Script 级变量的存活期从被声明的一刻起,直到 Script 运行结束。对于过程级变量,其存活期仅是该过程运行的时间,该过程结束后,变量随之消失。在执行过程时,局部变量是理想的临时存储空间。可以在不同过程中使用同名的局部变量,这是因为每个局部变量只被声明它的过程识别。

给变量赋值

创建如下形式的表达式给变量赋值:变量在表达式左边,要赋的值在表达式右边。例如:

B = 200

标量变量和数组变量

多数情况下,只需为声明的变量赋一个值。只包含一个值的变量被称为标量变量。有时候,将多个相关值赋给一个变量更为方便,因此可以创建包含一系列值的变量,称为数组变量。数组变量和标量变量是以相同的方式声明的,唯一的区别是声明数组变量时变量名后面带有括号 ( )。下例声明了一个包含 11 个元素的一维数组:

Dim A(10)

虽然括号中显示的数字是 10,但由于在 VBScript 中所有数组都是基于 0 的,所以这个数组实际上包含 11 个元素。在基于 0 的数组中,数组元素的数目总是括号中显示的数目加 1。这种数组被称为固定大小的数组。

在数组中使用索引为数组的每个元素赋值。从 0 到 10,将数据赋给数组的元素,如下所示:

A(0) = 256

A(1) = 324

A(2) = 100

A(10) = 55

与此类似,使用索引可以检索到所需的数组元素的数据。例如:

SomeVariable = A(8)

数组并不仅限于一维。数组的维数最大可以为 60(尽管大多数人不能理解超过 3 或 4 的维数)。声明多维数组时用逗号分隔括号中每个表示数组大小的数字。在下例中,MyTable 变量是一个有 6 行和 11 列的二维数组:

Dim MyTable(5, 10)

在二维数组中,括号中第一个数字表示行的数目,第二个数字表示列的数目。

也可以声明动态数组,即在运行 Script 时大小发生变化的数组。对数组的最初声明使用 Dim 语句或 ReDim 语句。但是对于动态数组,括号中不包含任何数字。例如:

Dim MyArray()

ReDim AnotherArray()

要使用动态数组,必须随后使用 ReDim 确定维数和每一维的大小。在下例中,ReDim 将动态数组的初始大小设置为 25,而后面的 ReDim 语句将数组的大小重新调整为 30,同时使用 Preserve 关键字在重新调整大小时保留数组的内容。

ReDim MyArray(25)

ReDim Preserve MyArray(30)

重新调整动态数组大小的次数是没有任何限制的,但是应注意:将数组的大小调小时,将会丢失被删除元素的数据。

最好的方法是把username拼入SQL中,每次检查都重新查询,这样判断最简单,而且最准确,实时性好。

次之的方法是取完检索结果,放入Reader中或者DataTable中循环比对,但Reader需要释放,不适合一直保存,而且循环一次后再循环还不方便,DataTable适合一直保存,随时比对,这两种方式都不需要逐个赋值,相对比较方便。

再次就是用List,先对检索结果循环,将结果赋值给List,然后用List循环和username比较。

以上就是关于oracle数据库怎样查询用变量表示的字段名全部的内容,包括:oracle数据库怎样查询用变量表示的字段名、什么是变量、C#语言。从数据库查询几个值出来,判断一个变量username是否等于这些变量中的一个,怎么做啊等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9624517.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存