传智播客——数据库之ORACLE(二)

 

  1) 用SELECT语句从表中提取查询数据。语法为
  SELECT [DISTINCT] {column1,column2,…} FROM tablename WHERE {conditions} GROUP BY {conditions} ORDER BY {expressions} [ASC/DESC]; 
  说明:SELECT子句用于指定检索数据库的中哪些列,FROM子句用于指定从哪一个表或视图中检索数据。
   2) SELECT中的操作符及多表查询WHERE子句。(LIKE,IS,…)
   WHERE子句中的条件可以是一个包含等号或不等号的条件表达式,也可以是一个含有IN、NOT IN、BETWEEN、LIKE、IS NOT NULL等比较运算符的条件式,还可以是由单一的条件表达通过逻辑运算符组合成复合条件。
   3) ORDER BY  子句
  ORDER BY 子句使得SQL在显示查询结果时将各返回行按顺序排列,返回行的排列顺序由ORDER BY 子句指定的表达式的值确定。
   4) 连接查询
  利用SELECT语句进行数据库查询时,可以把多个表、视图的数据结合起来,使得查询结果的每一行中包含来自多个表达式或视图的数据,这种操作被称为连接查询。
  连接查询的方法是在SELECT命令的FROM子句中指定两个或多个将被连接查询的表或视图,并且在WHERE子句告诉ORACLE如何把多个表的数据进行合并。根据WHERE子句中的条件表达式是等还是不等式,可以把连接查询分为等式连接和不等式连接。
   5) 子查询
  如果某一个SELECT命令(查询1)出现在另一个SQL命令(查询2)的一个子句中,则称查询1是查询2的子查询。
  
 基本数据类型(NUMBER,VARCHAR2,DATE) O
   RACEL支持下列内部数据类型:
  l VARCHAR2 变长字符串,最长为2000字符。
  l NUMBER  数值型。
  l LONG   变长字符数据,最长为2G字节。
  l DATE    日期型。
  l RAW    二进制数据,最长为255字节。
  l LONG RAW 变长二进制数据,最长为2G字节。
  l ROWID   二六进制串,表示表的行的唯一地址。
  l CHAR    定长字符数据,最长为255。
  
   6、 常用函数用法:
   一个函数类似于一个算符,它操作数据项,返回一个结果。函数在格式上不同于算符,它个具有变元,可操作0个、一个、二个或多个变元,形式为:
  函数名(变元,变元,…)
  函数具有下列一般类形:
 
   分组函数
  1) 单行函数对查询的表或视图的每一行返回一个结果行。它有数值函数,字符函数,日期函数,转换函数等。
  2) 分组函数返回的结果是基于行组而不是单行,所以分组函数不同于单行函数。在许多分组函数中可有下列选项:
  DISTRNCT 该选项使分组函数只考虑变元表达式中的不同值。
  ALL该选项使分组函数考虑全部值,包含全部重复。
  全部分组函数(除COUNT(*)外)忽略空值。如果具有分组函数的查询,没有返回行或只有空值(分组函数的变元取值的行),则分组函数返回空值。
   7、 数据操纵语言命令:
  数据库操纵语言(DML)命令用于查询和操纵模式对象中的数据,它不隐式地提交当前事务。它包含UPDATE、INSERT、DELETE、EXPLAIN PLAN、SELECT和LOCK TABLE 等命令。下面简单介绍一下:
   1) 更新
UPDATE tablename SET {column1=expression1,column2=expression2,…} WHERE {conditions};
  例如:S QL>UPDATE EMP 
   SET JOB =’MANAGER’
   WHERE ENAME=’MAPTIN’;
   SQL >SELECT * FROM EMP;
  UPDATE子句指明了要修改的数据库是EMP,并用WHERE子句限制了只对名字(ENAME)为’MARTIN’的职工的数据进行修改,SET子句则说明修改的方式,即把’MARTION’的工作名称(JOB)改为’MARAGER’.
  2)插入
 INSERT INTO tablename {column1,column2,…} VALUES {expression1,expression2,…};
  例如:SQL>SELECT INTO DEPT(DNAME, DEPTNO)
   VALUES (‘ACCOUNTING’,10)
   3)删除
  DELETE FROM tablename WHERE {conditions};
  例如:SQL>DELETE FROM EMP 
   WHERE EMPNO = 7654;
  DELETE命令删除一条记录,而且DELETE命令只能删除整行,而不能删除某行中的部分数据.
   4) 事务控制命令
  提交命令(COMMIT):可以使数据库的修改永久化.设置AUTOCOMMIT为允许状态:SQL >SET AUTOCOMMIT ON;
  回滚命令(ROLLBACK):消除上一个COMMIT命令后的所做的全部修改,使得数据库的内容恢复到上一个COMMIT执行后的状态.使用方法是:
  SQL>ROLLBACK;
学习总结:oracle的函数和命令行与mysql还是有不小区别的,学习时必须弄清楚差别,不然很容易混淆

你可能感兴趣的:(传智播客——数据库之ORACLE(二))