dual在oracle中是啥意思?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了dual在oracle中是啥意思?相关的知识,希望对你有一定的参考价值。

dual是Oracle中的一个伪表,利用这个伪表可以设置或查看序列,或者是调用一些内置的函数,方便操作。
如:
SELECT SYSDATE FROM dual;
SELECT seq.nextval FROM dual;
参考技术A 简单来说,dual表就是oracle与数据字典自动创建的一张表,这张表是一个单行单列的表,这个表只有1列:DUMMY,数据类型为VERCHAR2(1),dual表中只有一个数据'X', Oracle有内部逻辑保证dual表中永远只有一条数据。dual表主要是用来选择系统变量或是求一个表达式的值。
比如:
--求系统当前时间
SELECT sysdate FROM daul

--求系统当前时间,并按设定的格式显示
select to_char(sysdate,''yyyy-mm-dd hh24:mi:ss'') from dual;
--当计算器使用
select 1+2 from dual

.class 在 Java 中是啥意思?

【中文标题】.class 在 Java 中是啥意思?【英文标题】:What does .class mean in Java?.class 在 Java 中是什么意思? 【发布时间】:2013-02-11 07:16:16 【问题描述】:

.class 在 Java 中是什么意思?例如,如果我创建了一个名为 Print 的类。 Print.class 返回什么?

【问题讨论】:

docs.oracle.com/javase/tutorial/reflect/class/classNew.html 这对我来说确实是一个真实的问题。我只是自己问这个问题,在快速谷歌搜索后发现自己在这里。如果我知道我的问题不是真的,我想我不应该打扰! 另外,我认为由于特定搜索字符串的尴尬,关于这个问题几乎没有书面或可找到的内容。除了上面链接的 API 文档之外,我从未在其他任何地方看到过这种表示法(尽管您经常看到它在反射中使用)。 @MadProgrammer OP 询问 .class 语法,该语法只是偶然与 .class 文件扩展名相关。 类似于 C# 中的 typeof(MyType)。 (即:静态获取“类型”对象) 【参考方案1】:

补充以上答案:

假设您有一个名为“myPackage.MyClass”的类。假设在类路径中,以下语句是等价的。

//checking class name using string comparison, only Runtime check possible
if(myInstance.getClass().getName().equals(Class.forName("myPackage.MyClass")).getName())

//checking actual Class object for equality, only Runtime check possible
if(myInstance.getClass().getName() == Class.forName("myPackage.MyClass")))

//checking actual Class object for equality, but compile time validation
//will ensure MyClass is in classpath. Hence this approach is better (according to fail-fast paradigm)
if(myInstance.getClass() == MyClass.class)

同样,以下也是等价的。

Class<?> myClassObject = MyClass.class; //compile time check

Class<?> myClassObject = Class.forname("myPackage.MyClass"); //only runtime check

如果 JVM 加载一个类型,代表该类型的类对象将出现在 JVM 中。我们可以从反射包中非常常用的类对象中获取有关类型的元数据。 MyClass.class 是一个简写方法,它实际上指向代表 MyClass 的 Class 对象。

作为附录,一些关于类> 参考的信息将有助于阅读,因为大多数情况下,它们是一起使用的。

Class> 引用类型可以包含代表任何类型的任何 Class 对象。

如果 Class> 引用也在方法参数中,则以类似的方式工作。

请注意,“Class”类没有公共构造函数。所以你不能用“new”操作符来实例化“Class”实例。

【讨论】:

【参考方案2】:

.class 在没有可用的类实例时使用。

.getClass() 在有可用的类实例时使用。

object.getClass() 返回给定对象的类。

例如:

String string = "hello";
System.out.println(string.getClass().toString());

这将输出:

class java.lang.String

这是字符串对象的类:)

【讨论】:

getClass() 仅在您有指向类对象的引用时才有用。即使类没有实例,也可以使用ClassName.class。例如,考虑Math.class。在某些情况下,每个都是正确的。 精彩的解释。切中要害。喜欢你如何区分.class.getClass().【参考方案3】:

当你在类名后面写.class 时,它引用了类文字 - java.lang.Class 对象表示关于给定类的信息。

例如,如果您的类是 Print,那么 Print.class 是一个对象,它在运行时表示类 Print。它与Print 的任何(直接)实例的getClass() 方法返回的对象相同。

Print myPrint = new Print();
System.out.println(Print.class.getName());
System.out.println(myPrint.getClass().getName());

【讨论】:

类对象可以做哪些事情? @Kevin 请参阅java.lang.Class 的 API 文档。 那么Print.class的类型是什么? Android 是如何处理new Intent(this, Activity.class 的?它会尝试通过比较每个类来找出class Activity吗? @ZhipengYANG,类型为Class&lt;Print&gt;【参考方案4】:

类字面量是一个表达式,由类名、接口名、数组名或原始类型或伪类型 void 组成,后跟一个 '.'和令牌类。 JDK 5.0 的变化之一是类 java.lang.Class 是通用的,java.lang.Class Class&lt;T&gt;,因此:

Class<Print> p = Print.class;

此处参考:

https://docs.oracle.com/javase/7/docs/api/java/lang/Class.html

http://docs.oracle.com/javase/tutorial/extra/generics/literals.html

http://docs.oracle.com/javase/specs/jls/se7/html/jls-15.html#jls-15.8.2

【讨论】:

【参考方案5】:

澄清一下,这个 '.class' 方法并不是指你在编译 java 代码后看到的字节码文件,也不是 OOP 理论中 Class 与 Object 概念之间的混淆。

这个 '.class' 方法在 Java 中用于代码反射。通常,您可以为您的类收集元数据,例如完整的限定类名称、常量列表、公共字段列表等。

查看这些链接(上面已经提到)以获取所有详细信息:https://docs.oracle.com/javase/tutorial/reflect/class/classNew.htmlhttps://docs.oracle.com/javase/8/docs/api/java/lang/Class.html

通常,您不会在开始构建项目时立即使用反射。这是您在尝试管理已经工作的代码后知道需要的东西。很多时候,您需要它来管理程序的多个实例。也许您想识别每个特定的“克隆”以确定是否已经定义了某些内容,或者计算函数的数量,或者只是简单地记录类的特定实例的详细信息。

【讨论】:

【参考方案6】:

如果没有可用的实例,则使用.class 语法来获取类对应的 Class 对象,否则您可以使用 getClass() 方法获取 Class 对象。由于没有原始数据类型的实例,我们必须对原始数据类型使用.class 语法。

    package test;

    public class Test 
       public static void main(String[] args)
       
          //there is no instance available for class Test, so use Test.class
          System.out.println("Test.class.getName() ::: " + Test.class.getName());

          // Now create an instance of class Test use getClass()
          Test testObj = new Test();
          System.out.println("testObj.getClass().getName() ::: " + testObj.getClass().getName());

          //For primitive type
          System.out.println("boolean.class.getName() ::: " + boolean.class.getName());
          System.out.println("int.class.getName() ::: " + int.class.getName());
          System.out.println("char.class.getName() ::: " + char.class.getName());
          System.out.println("long.class.getName() ::: " + long.class.getName());
       
    

【讨论】:

【参考方案7】:

如果一个对象的实例可用,那么获取其 Class 的最简单方法是调用 Object.getClass()

.class 语法

如果类型可用但没有实例,则可以通过将.class 附加到类型名称来获得一个类。这也是获取原始类型的 Class 的最简单方法。

boolean b;
Class c = b.getClass();   // compile-time error

Class c = boolean.class;  // correct

见:docs.oracle.com about class

【讨论】:

【参考方案8】:

我认为这里的关键是理解类和对象之间的区别。对象是类的实例。但在完全面向对象的语言中,类也是对象。所以调用.class 会得到对该类的类对象的引用,然后可以对其进行操作。

【讨论】:

in a fully object-oriented language, a Class is also an Object?

以上是关于dual在oracle中是啥意思?的主要内容,如果未能解决你的问题,请参考以下文章

Oracle的dual是啥东西啊

Oracle中的数字(5)在C#中是啥意思

这个 Oracle SQL Developer 图标在我的存储过程中是啥意思?

=> 在 oracle pl sql.is 和调用运算符中是啥意思?

.class 在 Java 中是啥意思?

“?”是啥意思?在 Erlang 中是啥意思? [复制]