【oracle】学习笔记

DBMS_METADATA 查看数据库表结构

select dbms_metadata.get_ddl(相当于一个获取DDL的函数)('TABLE','表名')(都要大写)from dual;(此方法可以同样查询存储过程等)

 

表结构显示不完全时需要设置显示大小:

set long999;

set linesize 200;

set pagesize 0;

 

主键三个特点:非空、唯一(值唯一)、有且只有一个(每个表只能有一个主键集合)。

 

char为定长,varchar为变长。

1.varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;

2.VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;

3.VARCHAR2字符要用几个字节存储,要看数据库使用的字符集,

大部分情况下建议使用varchar2类型,可以保证更好的兼容性

 

连接运算符||

别名包含空格或者特殊字符,或者区分大小写,需要使用双引号。

日期和字符文字值必须放在单引号内。

去重关键字:distinct

 

默认升序:ASC       降序的话加:DESC

ASCII码中数字在前字母在后

 

日期默认显示格式:DD-MON-RR    17-JUN-87

select * from table where date = to_date("21-05-2008","dd-mm-yyyy")

 

<>  != 都是不等于的意思

 

单行函数:

 

优先级规则(可以使用括号修改优先级)

 

 

常用字符函数:

lower:全部转换成小写     upper:全部转换成大写        initcap:每个单词首字母大写

 

数字函数:

round:将值四舍五入到指定的小数位

trunc:将值截断到指定的小数位

mod:返回除法运算的余数

round(45.923,0)结果为46

round(45.923,-1)结果为50

 

数据类型转换:to_char、to_date、to_number

 

 

NVL2(expr1,expr2,expr3):

功能:如果参数表达式expr1值为NULL,则NVL2()函数返回参数表达式expr3的值;如果参数表达式expr1值不为NULL,则NVL2()函数返回参数表达式expr2的值。

NVL( string1, replace_with):

功能:如果string1为NULL,则NVL函数返回replace_with的值,否则返回string1的值,如果两个参数都为NULL ,则返回NULL。

 

case  when then  when  then  else  作用相当于if  then  if  then  else

 

count(1)效率高于count(*),count(*)效率最低

count(1)与count(*)得到的结果一致,包含null值。count(字段)不计算null。count(null)结果恒为0。

 

 

30条数据,2个null,AVG只会计算28个数据的平均值,加上NVL会强制计算所有数据的平均值。

 

1》当分组筛选(group by)的时候 用having

2》其它情况用where

有having就一定要有group by连用,

用group by不一有having (它只是一个筛选条件用的)

不管是加不加索引 group by 都比 distinct 快。因此使用的时候建议选 group by

 

UNION 操作符用于合并两个或多个 SELECT 语句的结果集。(结构相同的不同查询结果)

 

commit和rollback都会使事务结束,事务结束之前不会更新到数据库中,并且事务结束之前新的事务不能执行,只能等待。

COMMIT:表示事务完成提交,即提交事务的所有操作,具体地说就是将事务中所有对数据库的更新写回到磁盘上的物理数据库中去,事务正常结束。

ROLLBACK:表示事务的回滚,即在事务运行的过程中发生了某种故障,事务不能继续进行,系统将事务中对数据库的所有以完成的操作全部撤消,滚回到事务开始的状态或设置的回滚点。

 

 

DML操作(增删查改和merge)属于显式声明事务,需要手动提交。

DDL和DCL操作属于隐式声明事务,自动提交。

DML是对数据的操作可以回滚,但是DDL是对数据库的操作,不能回滚。

 

备份表:create table 备份表名 as select *from 原表名;

 

truncate会从表中删除所有行,使表为空并保存表结构不变。

是数据定义(DDL)语句而不是DML语句,无法轻易将其取消。

 

union操作符用于合并两个或者多个具有相同数量列的select语句的结果集。

union操作符选择不同的值,如果允许重复的值,可使用union all。

union的结果集只可以使用一个group by,union all的结果集可以使用多个group by;

 

to_number方法只能将'123'转换成123,但是不能将字母转换成ascii码。ASCII('a')可以将字幕转换成ASCII码,chr(65)可以将数字转换成ASCII码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值