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码。