Oracle DB 总结(SQL)

--SQL结构查询语言
1 数据库定义语言(DDL)用于建立、删除和修改数据库对象
  CREATE
  ALTER
  DROP
  TRUNCATE
2 数据库操纵语言(DML)用于改变数据库表中的数据
  INSERT
  UPDATE
  DELETE
3 事务控制语言(TCL)用来维护数据一致性的语言
  COMMIT
  ROLLBACK
  SAVEPOINT
4 数据查询语言(DQL)用来查询索要查询的数据
  SELECT
5 数据库控制语言(DCL)Data Control Language 用于执行权限的授予和收回操作
  GRANT 授予,用于给用户和角色授予权限
  REVOKE 用于收回用户或角色已有的权限
  CREATE USER 创建用户
--------------------------------------------------------------------------
--创建表
CREATE TABLE TABLE_NAME(  
 id NUMBER(4) NOT NULL,
 name VARCHAR2(40),
 gender VARCHAR2(1) DEFAULT 'm'
);
--查看表结构
DESC table_name;
--修改表名称
RENAME old_name TO new_name;
--增加列
ALTER TABLE TABLE_NAME ADD( hiredate DATE DEFAULT sysdate );
--删除列
ALTER TABLE TABLE_NAME DROP (ID);
--修改列
ALTER TABLE TABLE_NAME MODIFY( );

--DML
--插入记录
INSERT INTO TABLE_NAME (column1,column2 ) VALUES(value1,value2 );
--更新表中的记录
UPDATE TABLE_NAME SET column1 = value1,column2 = value2  WHERE condition;
--删除记录
DELETE FROM TABLE_NAME  WHERE condition;
TRUNCATE TABLE TABLE_NAME;  --删除全表记录,变成空表;针对数据删除,立即生效,无法回退,

--字符串操作
CHAR   浪费空间,节省时间
VARCHAR2 浪费时间,节省空间
LONG varchar2加长版,存储变长字符串,最多可达2GB;每个表只能有一个;不能作为主键;不能建立索引;不能出现在查询条件中...
CLOB 存储定长或变长字符串,最多可达4GB
一般建议用 CLOB 替代 LONG 类型;
--连接字符串 CONCAT()  ||
 SELEcT CONCAT('Hello','World!') FROM dual;
SELECT 'Hello' || 'World' from dual;
--LENGTH(CHAR)
SELECT NAME,LEGTH(NAME) FROM TABLE_NAME;

UPPER 将字符串转换成大写
LOWER 将字符串转换成小写
INITCAP 将字符串转换成每个单词首字母大写,其余小写
select LOWER('HELLO WORLD') FROM DUAL;

--截去子串
TRIM(c2 from c1) 从c1的前后截去c2
LTRIM(C1,C2) 从c1的左边截去c2
RTRIM(c1,c2)从c1的右边截去c2
如果没有c2就截去空壳

LPAD(CHAR1,N CHAR2)  左补位函数
RPAD(CHAR1,N,CHAR2)   右补位函数

SUBSTR(CHAR,START,END)  截取从start到end的字符串;start为负数则从尾部开始;如果没end则到尾部
INSTR(CHAR1,CHAR2[n[,m]]) 返回子串char2在char1中的位置;从n位开始搜索,没指定则从1开始;m指定子串m次出现,不指定则取值1


NUMBER(P,S)
ROUND(n[,m]) 用于四舍五入,m指定小数后第m位
TRUNC(n[,m]) 用于截取
MOD(m,n) 返回m除以n的余数
CEIL(n) 向上取整
FLOOR(n)向下取整

--日期类型
DATE    
TIMESTAMP 
SELECT sysdate from dual;
SELECT to_char(systimestamp,'YYYY-MM-dd HH24:mm:ss.ff DY DAY') from dual ;
--返回指日期的当月最后一天
SELECT LAST_DAY(sysDATE) FROM dual;
--指定日期加上i个月后的日期
SELECT ADD_MONTHS(sysdate,20*12) from dual;
--计算两个日期间之间有多少个月MONTHS_BETWEEN
SELECT MONTHS_BETWEEN('2019-12-25',sysdate) from dual;
--NEXT_DAY 返回日期数据的下一个周几,周日为1
SELECT NEXT_DAY(sysdate , 1) from dual;

--LEAST、GREATEST 返回最小或最大值,比较的必须是同一类型
SELECT LEAST(34,555,7999,2,3344) from dual;
SELECT GREATEST(34,555,7999,2,3344) from dual;
--EXTRACT 从参数中提取date指定的年月日等
SELECT EXTRACT(YEAR FROM SYSDATE) FROM DUAL;
SELECT EXTRACT(MONTH FROM SYSDATE) FROM DUAL;
SELECT EXTRACT(DAY FROM SYSDATE) FROM DUAL;

--数据库中任何数据类型都可以取null值 
--null查询用 IS NULL
--NOT NULL非空约束

desc employees
select * from employees;
--NVL() 若第一参数为null,则取值第二参数
SELECT employee_id,first_name,salary,salary + NVL(commission_pct,10) as "sal" from employees;
--NVL2() 若第一参数为null,则取值第三参数;否则第一参数非null取值第二参数
SELECT employee_id,first_name,salary,salary + NVL2(commission_pct,10,14) as "sal2" from employees;

--此处省略见 Oracle Day03(SQL)

--子查询 
子查询就是一个SQL语句(通常是SQL)中嵌套一个查询语句,嵌套的这个语句就是子查询语句
梓槎村也可以用于DML和DDL语句

--分页查询
ROWNUM 

--分支函数 
--DECODE,  最后一个为default当前面都不满足则执行default;
SELECT NAME ,SAL(
DECODE(job,
  'MANAGER',SAL*1.2,
  'ANALYST',SAL*1.1,
  'SALESMAN',SAL*1.5,
  SAL)
) FROM TABLE_NAME
--CASE
SELECT NAME ,SAL(
  CASE job WHEN  'MANAGER' THEN SAL*1.2
           WHEN 'ANALYST' THEN SAL*1.1
           WHEN 'SALESMAN' THEN SAL*1.5
           ELSE SAL END
           
  bonus
)FROM TABLE_NAME;


--排序函数
ROW_NUMBER() OVER(PARTITION BY col1 ORDER BY col2 ) 排名连续且唯一,根据col1分组,在分组里根据col2排序
RANK() OVER ( PARTITION BY col1 ORDER BY col2) 排名可以相同有重复值,会产生不连续
DENSE_RANK() OVER(PARTITION BY col1 ORDER BY col2) 相同数据返回相同排名,且排名连续


--集合操作
UNION 并集,每个元素只有一个
UNION ALL  并集,有重复元素
INTERSECT 交集,获取两个结果集的交集
MINUS 差集



--高级分组函数
-- ROLLUP , CUBE , GROUPING SETS 运算符是 GROUP BY 子句的扩展,  
GROUP BY ROLLUP(A,B,C) --按照阶梯状进行分组 n 个参数 ,则会有 n+1 次分组
GROUP BY CUBE (A,B,C) --按照n个参数,则会有 2^n 次分组
GROUP BY GROUPING SETS((A),(B))  --可以指定分组


--视图 分为:简单视图 和 复杂视图 ;select基于多个表叫做 连接视图
  目的:1简化复杂查询,查询复用;2 限制数据访问
-- 简单视图:基于单表建立的,不包含任何函数运算和分组、表达式或分组函数,即简单取出基表记录不做任何改变
  -- 对简单视图做的 insert、update、 delete 等操作就是就基表的操作
WITH CHECK OPTION 给视图添加约束,只能做视图可见的 insertupdatedelete 等操作
WITH READ ONLY   保证视图对应的基表数据不会被非法修改

-- 复杂函数:基于单表,但包含单行函数、表达式、分组函数或GROUP BY子句等 
视图也叫做虚拟表,是一组数据的逻辑表示;
视图对应一条 SELECT 语句,结果集被赋予一个名字 ,即叫做视图;
视图本身不包含任何数据,它只包含映射到基表的一个查询语句,当基表数据发生变化,视图数据也会随之改变;
CREATE VIEW v_TableName_ViewName  AS SELECT SAL FROM TABLE_NAME;
DROP VIEW VIEW_NAME;
视图的可以向表一样查询结构等;

--和视图相关的数据字典
-- USER_OBJECTS  查询所有视图名称
SELECT object_name FROM USER_OBJECTS
WHERE object_type = 'VIEW';

-- USER_VIEWS 查询指定视图
SELECT text FROM USER_VIEWS
WHERE view_name = 'v_EMP_10';

-- USER_UPDATE_COLUMNS 
SELECT column_name,insertable,updatable,deletable
FROM user_updatable_columns
WHERE table_name = 'V_emp_10';


--序列 SEQUENCE 是一种用来生成唯一数字值的数据库对象
CREATE SEQUENCE sequence_name 
[START WITH i] [INCREMENT BY j]
[MAXVALUE m] [NOMAXVALUE]
[MINVALUE n] [NOMINVALUE]
[CYCLE | NOCYCLE ] [ CACHE p | NOCACHE]
sequence_name 是序列名,序列的第一个值是 i ,步进 j ;如果j是正数,表示递增,如果是负数,表示递减;
序列可生成的最大值是m,最小值是n;
如果没有任何可选参数,序列的第一个值是1,步进是1;
CYCLE 表示在递增至最大值或递减至最小值之后是否继续生成序列号,默认值是NOCYCLE;
CACHE 用来指定先预定取P个数据在缓存中,以提高序列值得生成效率,默认值是20;

CREATE SEQUENCE sequence_name 
  start with 100
  increment by 10

NEXTVAL  获取序列的下个值,不能回退
CURRVAL 获取序列的当前值,必须限制性一个nextval才能用currval

SELECT sequence_name.nextval   FROM DUAL;
SELECT sequence_name.currval FROM DUAL;

--s删除序列
DROP SEQUENCE sequence_name



--索引
  索引是一种允许直接访问数据表中某一数据行的树形结构,为了提高查询效率而引入,是独立于表的对象,
  可以存放在表不同的表空间(TABLESPACE)中;
  索引记录中存有 索引关键字 和 指向表中数据的指针;
  小数据量不需要索引;
  限制表上索引的数目,索引并不是越多越好
  删除很少使用、不合理的索引;
  不要在经常做DML操作的表上建立索引;
  
  
  索引是数据库自行维护和使用,
  --创建索引
  CREATE INDEX index_name ON table(column1[,column2...])
  --删除索引
  DROP INDEX index_name;
  --修改索引
  ALTER INDEX index_name REBUILD;
  
  
--约束:全称是约束条件,也称作完整性约束条件;
      约束是在数据表上强制执行的一些数据消炎规则,当执行DML操作时必须遵循这些规则,若果不符合无法执行;
      约束条件可以保证表中数据的完整性,保证数据间的商业逻辑;
  非空约束 NOT NULL 简称 NN  ,确保字段不为空值 
      --创建时添加约束
      CREATE TABLE emp (
      id number(6) NOT NULL,
      hiredate DATE CONSTRAINT emp_hirdate_nn NOT NULL
      );
      --修改时添加约束
      ALTER TABLE emp MODIFY (id NUMBER(6) NOT NULL);
      
  唯一性约束 Unique 简称 UK,确保字段不出现重复值,null可以重复,同样可以创建和修改表是添加;
      ALTER TABLE emp ADD CONSTRAINT emp Unique(name);
    
  主键约束 Primary Key 简称 PK, NOT NULL 加上 Unique ;用法同上
  
  外键约束 Foreign Key 简称 FK
  
  检查约束 Check 简称 CK,用来强制在字段上的每个值都要满足Check中定义的条件
    ALTER TABLE emp ADD CONSTRAINT emp_salary_check CHECK(salary >2000);
      
  
  

 

posted @ 2019-03-31 22:46  KwinWei  阅读(549)  评论(0编辑  收藏  举报