ORACLE中单双引号的不同效果

😂 这篇文章最后更新于1473天前,您需要注意相关的内容是否还可用。
目录导航
  • 在Oracle中
    • 双引号的作用
    • 而单引号则表示
  • 在SQL中
  • 在Oracle中

    双引号的作用

    如果创建对象的时候,对象名、字段名加双引号,则表示Oracle将严格区分大小写,否则Oracl都默认大写;双引号一般是用来转义的,如果alias里面有空格或其它保留符号,必须使用双引号。

    而单引号则表示

    这个加了单引号的字段是一个字类似字符串,并不区分大小写;单引号是用来特制的,比如字符串的引用,日期字符串的引用,都必须包括在单引号中,可以参与运算或其它表达式中。

    两者不可混用,其中,两个单引号可以作为单引号的转义使用,意思就是一个真正的、没有特殊功能的单引号。例如 select substr('I''am a pig',1,4)。

    在SQL中

    表示字符串得引号强烈建议使用单引号(')。虽然MySQL也可以使用双引号("),但是为了和SQL Server和Oracle统一,建议都使用单引号。如果在字符串中也有单引号出现的话,在SQL中需要将其替换为两个单引号(''),DBMS会将其解释为一个单引号的。 关于SQL的换行符和字符串连接符,在MySQL、SQL Server和Oracle中均有不同,下面以列表显示。


    MySQL

    SQL Server

    Oracle

    换行符

    /n或/r/n或CHAR(10)

    CHAR(13)

    CHR(10)

    字符串连接符

    CONCAT()

    +

    ||或CONCAT()

    单引号用于标识字符与数字的区别
    例如
    select * from table_name where id=1;这种代表查询的是数字
    select * from table_name where id='1';这种代表查询的是字符

    如果是双引号是这样,假如你有个表的字段叫sysdate,因为sysdate属于oracle中的特有字符,但你要查询这个字段的时候
    select "sysdate" from table_name;
    但是你要是用
    select 'sysdate' from table_name;
    那么你查出来的就是字符串,结果是sysdate。

    文章转载于https://blog.csdn.net/wanghai__/article/details/4700942