- 浏览: 116416 次
- 性别:
- 来自: 北京
最新评论
-
龍行天下:
大神你好,请教你,ajax怎么访问数据库并返回list对象,对 ...
菜鸟分享ajax基础 -
xhdyw1225:
老板,可以提供源码下载吗? 初学这玩意,有调通的源码学习方 ...
Spring+Hibernate两种方法实现增删改查 -
hongmeikaile:
我总结好长时间,都是一些基础的知识,特别适合ORACLE初学者 ...
超详细SQL常用函数总结 -
hongmeikaile:
自己先评价一下噢!哈哈。。。继续努力!
jQuery基础知识总结(二) -
hongmeikaile:
其实最好的学习参考还是API,目前的最新版本是:jQueryA ...
jQuery基础知识总结(二)
Sql总结之Sql--常用函数
一、字符串函数是oracle使用最广泛的一种函数(表是参考sql查询介绍(二)中的表).
A、LOWER(参数):把参数变成小写
例如:查询名称为scott的员工信息 (不区分大小写的查询)
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where lower(ename)='scott';
输出的结果是:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
B、UPPER(参数):把参数变成大写
例如:查询名称为scott的员工信息 (不区分大小写的查询)
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where upper(ename)='scott';
输出的结果是:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
C、INITCAP(参数): 把参数的首字母大写
例如:查找员工编号是7788的信息,他的名字显示成首字母大写
SQL> select empno,initcap(ename),job,mgr,hiredate,sal,comm,deptno from emp where empno='7788';
显示结果是:
EMPNO INITCAP(ENAME) JOB MGR HIREDATE SAL COMM DEPTNO
----- -------------- --------- ----- ----------- --------- --------- ------
7788 Scott ANALYST 7566 1982-12-9 3000.00 20
D、LENGTH(参数): 返回参数的长度
例如:输出员工编号是7788的job的长度
SQL> select length(job) as "7788的job的length" from emp where empno=7788;
显示的结果如下:
7788的job的length
-----------------
7
E、CONCAT(参数1,参数2): 把参数1和参数2连接起来
例如:把员工7788的工资显示成:薪水+奖金
SQL> select empno,ename,job,mgr,hiredate,concat(sal,comm) as "工资",deptno from emp where empno='7788';
显示的结果如下:
EMPNO ENAME JOB MGR HIREDATE 工资 DEPTNO
----- ------ ------ ----- ----------- ---------------- ------
7788 SCOTT ANALYST 7566 1982-12-9 3000 20
F、SUBSTR(参数,开始,截取数目): 截取参数
例如:输出员工编号是7788的job的后三位
SQL> select empno,ename,job,substr(job,length(job)-2,3) as "job的后三位" from emp where empno=7788; 或:
select empno,ename,job,substr(job,length(job)-2) as "job的后三位" from emp where empno=7788;显示的结果如下:
EMPNO ENAME JOB job的后三位
----- ---------- --------- ------------
7788 SCOTT ANALYST YST
G、INSTR(参数,字母): 返回字母首次出现的位置
例如:查找用户7788的名字中‘T’出现的位置
SQL> select empno,ename,instr(ename,'T') as "T首次出现的位置" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME T首次出现的位置
----- ---------- ---------------
7788 SCOTT 4
H、LPAD(参数,长度,在前补齐参数字母):向左补齐
例如:查找用户是7788的薪水,如果不够4位的话,前面补0
SQL> select empno,ename,sal,lpad(sal,6,'0') as "薪水是6位的格式" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME SAL 薪水是6位的格式
----- ---------- --------- ------------------------
7788 SCOTT 3000.00 003000
I、RPAD(参数,长度,在后补齐参数字母):向右补齐
例如:查找用户是7788的薪水,如果不够4位的话,前面补0
SQL> select empno,ename,sal,rpad(sal,6,'0') as "薪水是6位的格式" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME SAL 薪水是6位的格式
----- ---------- --------- ------------------------
7788 SCOTT 3000.00 300000
J、TRIM([both||leadingtrailing||]字母 from 参数):从参数中去掉指定的字母
例如:查找员工编号是7788的去掉“T”后的员工姓名
SQL> select empno,ename,trim('T' from ename) as "去掉T后" from emp where empno=7788;
或
SQL> select empno,ename,trim(both 'T' from ename) as "去掉T后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 去掉T后
----- ---------- ----------
7788 SCOTT SCO
例如:查找员工编号是7788的去掉左边的“T”后的员工姓名
SQL> select empno,ename,trim(leading 'T' from ename) as "去掉T后" from emp where empno=7788;
或:
SQL> select empno,ename,ltrim(ename,'T') as "去掉T后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 去掉T后
----- ---------- ----------
7788 SCOTT SCOTT
例如:查找员工编号是7788的去掉右边的“T”后的员工姓名
SQL> select empno,ename,trim(trailing 'T' from ename) as "去掉T后" from emp where empno=7788;
或:
SQL> select empno,ename,rtrim(ename,'T') as "去掉T后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 去掉T后
----- ---------- ----------
7788 SCOTT SCO
K、REPLACE:(参数,参数[,参数]): 第一个参数操作数,第二是要查找的字符,第三个是替换的字符,如果没有第三个就删除查找的字符。
例如:把编号7788的员工姓名中的‘T’换成‘L’
SQL> select empno,ename,replace(ename,'T','L') as "替换后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 替换后
----- ---------- ----------
7788 SCOTT SCOLL
二、数字函数
A、ROUND(参数): 四舍五入
例如:查找12.89的四舍五入
SQL> select round(12.89) from dual;
显示的结果如下:
ROUND(12.89)
------------
13
B、TRUNC(参数1[,参数2]): 截断 ,第一个参数是要操作的数,第二个参数可有可无,如果没有的话,截断的是整数部分,如果参数2是正数的话,截取小数点右边的‘参数2’个数,如果是负数的话,截取小数点左边的“参数2”个数
例如:采用默认的方式
SQL> select trunc(12.89) from dual;
显示的结果:
TRUNC(12.89)
------------
12
例如:第二个参数是正数的时候
SQL> select trunc(12.89,1) from dual;
显示的结果:
TRUNC(12.89,1)
--------------
12.8
例如:第二个参数是负数的时候
SQL> select trunc(12.89,-1) from dual;
显示的结果:
TRUNC(12.89,-1)
---------------
10
C、MOD(参数1,参数2): 求参数1除以参数2后的余数
例如:100除以30的余数
SQL> select mod(100,30) from dual;
显示的结果:
MOD(100,30)
-----------
10
D、ABS(参数):求参数的绝对值
例如:求-10 的绝对值
SQL> select abs(-10) from dual;
显示的结果:
ABS(-10)
----------
10
E、CEIL(参数):返回大于或等于参数的最小整数
SQL> select ceil(-10.23) from dual;
显示的结果:
CEIL(-10.23)
------------
-10
F、FLOOR(参数):返回小于或等于参数的最大整数
例如:求-10.23的向下取整
SQL> select floor(-10.23) from dual;
显示的结果:
FLOOR(-10.23)
------------
-11
G、SQRT(参数) :返回参数的平方根 负数无意义。
例如:求4的平方根
SQL> select sqrt(4) from dual;
显示的结果:
SQRT(4)
----------
2
日期函数:Oracle 中的日期型数据实际含有两个值: 日期和时间。默认的日期格式是 DD-MON-RR.日期时间函数用来返回当前系统的日期和时间、以及对日期和时间类型的数据进行处理运算。
A、sysdate();获取系统的当前日期
例如:
SQL> select sysdate from dual;
显示的结果是:
SYSDATE
-----------
2011-4-8 13
B、current_timestamp();获取当前的时间和日期值
例如:
SQL> select current_timestamp from dual;
显示的结果是:
CURRENT_TIMESTAMP
--------------------------------------------------------------------------------
08-4月 -11 01.38.27.546000 下午 +08:00
C、add_months(date,count):在指定的日期上增加count个月
例如:输出当前时间的加上3个月的后的时间
SQL> select add_months(sysdate,3) from dual;
显示结果:
ADD_MONTHS(SYSDATE,3)
---------------------
2011-7-8 13:43:06
D、last_day(date);返回日期date所在月的最后一天
例如:
SQL> select sysdate,last_day(sysdate) from dual;
显示结果:
SYSDATE LAST_DAY(SYSDATE)
----------- -----------------
2011-4-8 13 2011-4-30 13:51:2
E、months_between(date1,dates);返回date1到date2之间间隔多少个月
例如:
SQL> select sysdate,months_between(sysdate,add_months(sysdate,3)) from dual;
显示结果:
SYSDATE MONTHS_BETWEEN(SYSDATE,ADD_MON
----------- ------------------------------
2011-4-8 13 -3
F、new_time(date,'this','other');将时间date从this时区转换成other时区
例如:
SQL> select sysdate,new_time(sysdate,'GMT','AST') from dual;
显示结果:
SYSDATE NEW_TIME(SYSDATE,'GMT','AST')
----------- -----------------------------
2011-4-8 13 2011-4-8 9:
G、next_day(day,'week');返回指定日期或最后一的第一个星期几的日期,这里day为星期几
例如:
SQL> select sysdate,next_day(sysdate,'星期五') from dual;
显示结果:
SYSDATE NEXT_DAY(SYSDATE,'星期五')
----------- --------------------------
2011-4-8 13 2011-4-15 13:53:10
H、round(参数,截取类型):日期的四舍五入
例如:四舍五入当前时间年
SQL> select sysdate,round(sysdate,'yyyy') from dual;
显示结果:
SYSDATE ROUND(SYSDATE,'YYYY')
----------- ---------------------
2011-4-9 22 2011-1-1
例如:四舍五入当前时间月
SQL> select sysdate,round(sysdate,'mm') from dual;
显示结果:
SYSDATE ROUND(SYSDATE,'MM')
----------- -------------------
2011-4-9 22 2011-4-1
例如:四舍五入当前时间日
SQL> select sysdate,round(sysdate,'dd') from dual;
显示的结果:
SYSDATE ROUND(SYSDATE,'DD')
----------- -------------------
2011-4-9 22 2011-4-10
I、to_char(参数,转换的类型): 日期的截取
例如:截取当前时间的年
SQL> select sysdate,to_char(sysdate,'yyyy') from dual;
显示结果:
SYSDATE TO_CHAR(SYSDATE,'YYYY')
----------- -----------------------
2011-4-9 22 2011
例如:截取当前时间的月
SQL> select sysdate,to_char(sysdate,'mm') from dual;
显示结果:
SYSDATE TO_CHAR(SYSDATE,'MM')
----------- ---------------------
2011-4-9 22 04
例如:截取当前时间的日
SQL> select sysdate,to_char(sysdate,'dd') from dual;
显示结果:
SYSDATE TO_CHAR(SYSDATE,'DD')
----------- ---------------------
2011-4-9 22 09
日期的数学运算:
在日期上加上或减去一个数字结果仍为日期。
两个日期相减返回日期之间相差的天数。
可以用数字除24来向日期中加上或减去小时
通用函数
这些函数适用于任何数据类型,同时也适用于空值:
A、NVL (expr1, expr2):如果expr1为空的话,显示expr2
例如:查看emp如奖金comm为空的话,替换成0
SQL> select empno,ename,job,mgr,hiredate,sal,nvl(comm,0),deptno from emp;
显示结果:
EMPNO ENAME JOB MGR HIREDATE SAL NVL(COMM,0) DEPTNO
----- ---------- --------- ----- ----------- --------- ----------- ------
7369 SMITH CLERK 7902 1980-12-17 800.00 0 20
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300 30
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500 30
7566 JONES MANAGER 7839 1981-4-2 2975.00 0 20
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400 30
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 0 30
7782 CLARK MANAGER 7839 1981-6-9 2450.00 0 10
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 0 20
7839 KING PRESIDENT 1981-11-17 5000.00 0 10
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0 30
7876 ADAMS CLERK 7788 1983-1-12 1100.00 0 20
7900 JAMES CLERK 7698 1981-12-3 950.00 0 30
7902 FORD ANALYST 7566 1981-12-3 3000.00 0 20
7934 MILLER CLERK 7782 1982-1-23 1300.00 0 10
14 rows selected
B、NVL2 (expr1, expr2, expr3):如果expr1为不空的话,显示expr2,如果expr1为空的话,显示expr3
例如:查找员工的编号是7521的员工的工资,如果奖金(comm)不为空的话,显示工资加奖金
SQL> select sal,nvl2(comm,sal+comm,sal) from emp where empno=7521;
显示结果:
SAL NVL2(COMM,SAL+COMM,SAL)
--------- -----------------------
1250.00 1750
C、NULLIF (expr1, expr2):expr1与expr2相等返回NULL,不等返回expr1
例如:查看员工7788的薪水和奖金,如果薪水和奖金相等的话返回null,否则返回工资
SQL> select sal,comm,nullif(sal,comm) from emp where empno=7788;
显示结果:
SAL COMM NULLIF(SAL,COMM)
--------- --------- ----------------
3000.00 3000
D、COALESCE (expr1, expr2, ..., exprn):如果第一个表达式为空,则返回下一个表达式。COALESCE 与 NVL 相比的优点在于 COALESCE 可以同时处理交替的多个值
例如:在emp表中测试的
为了测试,向emp表中添加一条记录:
SQL> insert into emp(empno,ename,deptno) values(7978,'guo',10);
测试语句:
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno,coalesce(comm,sal,1000) as "测试结果" from emp;
显示结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO 测试结果
----- ---------- --------- ----- ----------- --------- --------- ------ ----------
7369 SMITH CLERK 7902 1980-12-17 800.00 20 800
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30 300
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30 500
7566 JONES MANAGER 7839 1981-4-2 2975.00 20 2975
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30 1400
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30 2850
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10 2450
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20 3000
7839 KING PRESIDENT 1981-11-17 5000.00 10 5000
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30 0
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20 1100
7900 JAMES CLERK 7698 1981-12-3 950.00 30 950
7902 FORD ANALYST 7566 1981-12-3 3000.00 20 3000
7934 MILLER CLERK 7782 1982-1-23 1300.00 10 1300
7978 guo 10 1000
15 rows selected
组合函数:
分组函数作用于一组数据,并对一组数据返回一个值。
A、AVG(字段名):求该字段的平均值
例如:求出emp表中工资的平均值
SQL> select avg(nvl(sal,0)) from emp;
显示结果:
AVG(NVL(SAL,0))
---------------
1935
B、COUNT(字段名):求该字段中的总记录
例如:查询emp表中有几条记录
SQL> select count(*) from emp;
显示结果:
COUNT(*)
----------
15
C、MAX(字段名):求该字段的最大值
例如:求出emp表中的最高的工资的员工
SQL> select max(nvl(sal,0)) from emp;
显示结果:
MAX(NVL(SAL,0))
---------------
5000
D、MIN(字段名):求该字段的最小值
例如:求出emp表中的最低的工资的员工
SQL> select min(nvl(sal,0)) from emp;
显示结果:
MIN(NVL(SAL,0))
---------------
0
E、SUM(字段名):求该字段的和
例如:求emp一个需要发多少工资
SQL> select sum(sal)+sum(comm) as "总工资" from emp;
显示结果:
MIN(NVL(SAL,0))
---------------
0
非法使用组函数
A、所用包含于SELECT 列表中,而未包含于组函数中的列都必须包含于 GROUP BY 子句中。
例如:
SQL> select empno,count(job) from emp;
正确写法如下:
SQL> select empno,count(job) from emp group by empno;
B、不能在 WHERE 子句中使用组函数(注意)。
例如:SQL> select deptno from emp where count(job)>0 group by deptno;
备注:ORA-00934: 此处不允许使用分组函数
group by 语句
如果在查询的过程中需要按某一列的值进行分组,以统计该组内数据的信息时,就要使用group by子句。不管select是否使用了where子句都可以使用group by子句。
注意:group by子句一定要与分组函数结合使用,否则没有意义。
求出每个部门的员工的数
SQL> select count(*) from emp group by deptno;
显示的结果:
COUNT(*)
----------
6
5
4
求每个部门的中员工的平均工资
SQL> select avg(nvl(sal,0)) from emp group by deptno;
显示的结果:
AVG(NVL(SAL,0))
---------------
1566.6666666666
2175
2187.5
Having子句
HAVING 子句对 GROUP BY 子句设置条件的方式与 WHERE 子句和 SELECT 语句交互的方式类似。WHERE 子句搜索条件在进行分组操作之前应用;而 HAVING 搜索条件在进行分组操作之后应用。HAVING 语法与 WHERE 语法类似,但 HAVING 可以包含聚合函数。HAVING 子句可以引用选择列表中出现的任意项。
备注:having子句通常与group by子句结合使用
语法:
SELECT column, group_function
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[HAVING group_condition]
[ORDER BY column];
A、查询部门的员工人数大于五部门编号
SQL> select deptno,count(*) from emp group by deptno having count(*)>5;
显示结果:
DEPTNO COUNT(*)
------ ----------
30 6
备注:分组函数可以嵌套
Order by语句
ORDER BY 子句在SELECT语句的结尾。使用 ORDER BY 子句排序 :ASC(ascend): 升序 ;DESC(descend): 降序 。默认的是ASC升序
查询员工信息按照部门的编号进行升序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by empno;
或:
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by empno asc;
显示的结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7369 SMITH CLERK 7902 1980-12-17 800.00 20
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30
7566 JONES MANAGER 7839 1981-4-2 2975.00 20
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
7839 KING PRESIDENT 1981-11-17 5000.00 10
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20
7900 JAMES CLERK 7698 1981-12-3 950.00 30
7902 FORD ANALYST 7566 1981-12-3 3000.00 20
7934 MILLER CLERK 7782 1982-1-23 1300.00 10
7978 guo 10
15 rows selected
查询员工信息按照部门的编号进行降序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by empno desc;
显示的结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7978 guo 10
7934 MILLER CLERK 7782 1982-1-23 1300.00 10
7902 FORD ANALYST 7566 1981-12-3 3000.00 20
7900 JAMES CLERK 7698 1981-12-3 950.00 30
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30
7839 KING PRESIDENT 1981-11-17 5000.00 10
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30
7566 JONES MANAGER 7839 1981-4-2 2975.00 20
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30
7369 SMITH CLERK 7902 1980-12-17 800.00 20
15 rows selected
按部门升序,员工编号降序查询
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno asc,empno desc;
显示的结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7978 guo 10
7934 MILLER CLERK 7782 1982-1-23 1300.00 10
7839 KING PRESIDENT 1981-11-17 5000.00 10
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10
7902 FORD ANALYST 7566 1981-12-3 3000.00 20
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
7566 JONES MANAGER 7839 1981-4-2 2975.00 20
7369 SMITH CLERK 7902 1980-12-17 800.00 20
7900 JAMES CLERK 7698 1981-12-3 950.00 30
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30
15 rows selected
一、字符串函数是oracle使用最广泛的一种函数(表是参考sql查询介绍(二)中的表).
A、LOWER(参数):把参数变成小写
例如:查询名称为scott的员工信息 (不区分大小写的查询)
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where lower(ename)='scott';
输出的结果是:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
B、UPPER(参数):把参数变成大写
例如:查询名称为scott的员工信息 (不区分大小写的查询)
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where upper(ename)='scott';
输出的结果是:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
C、INITCAP(参数): 把参数的首字母大写
例如:查找员工编号是7788的信息,他的名字显示成首字母大写
SQL> select empno,initcap(ename),job,mgr,hiredate,sal,comm,deptno from emp where empno='7788';
显示结果是:
EMPNO INITCAP(ENAME) JOB MGR HIREDATE SAL COMM DEPTNO
----- -------------- --------- ----- ----------- --------- --------- ------
7788 Scott ANALYST 7566 1982-12-9 3000.00 20
D、LENGTH(参数): 返回参数的长度
例如:输出员工编号是7788的job的长度
SQL> select length(job) as "7788的job的length" from emp where empno=7788;
显示的结果如下:
7788的job的length
-----------------
7
E、CONCAT(参数1,参数2): 把参数1和参数2连接起来
例如:把员工7788的工资显示成:薪水+奖金
SQL> select empno,ename,job,mgr,hiredate,concat(sal,comm) as "工资",deptno from emp where empno='7788';
显示的结果如下:
EMPNO ENAME JOB MGR HIREDATE 工资 DEPTNO
----- ------ ------ ----- ----------- ---------------- ------
7788 SCOTT ANALYST 7566 1982-12-9 3000 20
F、SUBSTR(参数,开始,截取数目): 截取参数
例如:输出员工编号是7788的job的后三位
SQL> select empno,ename,job,substr(job,length(job)-2,3) as "job的后三位" from emp where empno=7788; 或:
select empno,ename,job,substr(job,length(job)-2) as "job的后三位" from emp where empno=7788;显示的结果如下:
EMPNO ENAME JOB job的后三位
----- ---------- --------- ------------
7788 SCOTT ANALYST YST
G、INSTR(参数,字母): 返回字母首次出现的位置
例如:查找用户7788的名字中‘T’出现的位置
SQL> select empno,ename,instr(ename,'T') as "T首次出现的位置" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME T首次出现的位置
----- ---------- ---------------
7788 SCOTT 4
H、LPAD(参数,长度,在前补齐参数字母):向左补齐
例如:查找用户是7788的薪水,如果不够4位的话,前面补0
SQL> select empno,ename,sal,lpad(sal,6,'0') as "薪水是6位的格式" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME SAL 薪水是6位的格式
----- ---------- --------- ------------------------
7788 SCOTT 3000.00 003000
I、RPAD(参数,长度,在后补齐参数字母):向右补齐
例如:查找用户是7788的薪水,如果不够4位的话,前面补0
SQL> select empno,ename,sal,rpad(sal,6,'0') as "薪水是6位的格式" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME SAL 薪水是6位的格式
----- ---------- --------- ------------------------
7788 SCOTT 3000.00 300000
J、TRIM([both||leadingtrailing||]字母 from 参数):从参数中去掉指定的字母
例如:查找员工编号是7788的去掉“T”后的员工姓名
SQL> select empno,ename,trim('T' from ename) as "去掉T后" from emp where empno=7788;
或
SQL> select empno,ename,trim(both 'T' from ename) as "去掉T后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 去掉T后
----- ---------- ----------
7788 SCOTT SCO
例如:查找员工编号是7788的去掉左边的“T”后的员工姓名
SQL> select empno,ename,trim(leading 'T' from ename) as "去掉T后" from emp where empno=7788;
或:
SQL> select empno,ename,ltrim(ename,'T') as "去掉T后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 去掉T后
----- ---------- ----------
7788 SCOTT SCOTT
例如:查找员工编号是7788的去掉右边的“T”后的员工姓名
SQL> select empno,ename,trim(trailing 'T' from ename) as "去掉T后" from emp where empno=7788;
或:
SQL> select empno,ename,rtrim(ename,'T') as "去掉T后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 去掉T后
----- ---------- ----------
7788 SCOTT SCO
K、REPLACE:(参数,参数[,参数]): 第一个参数操作数,第二是要查找的字符,第三个是替换的字符,如果没有第三个就删除查找的字符。
例如:把编号7788的员工姓名中的‘T’换成‘L’
SQL> select empno,ename,replace(ename,'T','L') as "替换后" from emp where empno=7788;
显示的结果如下:
EMPNO ENAME 替换后
----- ---------- ----------
7788 SCOTT SCOLL
二、数字函数
A、ROUND(参数): 四舍五入
例如:查找12.89的四舍五入
SQL> select round(12.89) from dual;
显示的结果如下:
ROUND(12.89)
------------
13
B、TRUNC(参数1[,参数2]): 截断 ,第一个参数是要操作的数,第二个参数可有可无,如果没有的话,截断的是整数部分,如果参数2是正数的话,截取小数点右边的‘参数2’个数,如果是负数的话,截取小数点左边的“参数2”个数
例如:采用默认的方式
SQL> select trunc(12.89) from dual;
显示的结果:
TRUNC(12.89)
------------
12
例如:第二个参数是正数的时候
SQL> select trunc(12.89,1) from dual;
显示的结果:
TRUNC(12.89,1)
--------------
12.8
例如:第二个参数是负数的时候
SQL> select trunc(12.89,-1) from dual;
显示的结果:
TRUNC(12.89,-1)
---------------
10
C、MOD(参数1,参数2): 求参数1除以参数2后的余数
例如:100除以30的余数
SQL> select mod(100,30) from dual;
显示的结果:
MOD(100,30)
-----------
10
D、ABS(参数):求参数的绝对值
例如:求-10 的绝对值
SQL> select abs(-10) from dual;
显示的结果:
ABS(-10)
----------
10
E、CEIL(参数):返回大于或等于参数的最小整数
SQL> select ceil(-10.23) from dual;
显示的结果:
CEIL(-10.23)
------------
-10
F、FLOOR(参数):返回小于或等于参数的最大整数
例如:求-10.23的向下取整
SQL> select floor(-10.23) from dual;
显示的结果:
FLOOR(-10.23)
------------
-11
G、SQRT(参数) :返回参数的平方根 负数无意义。
例如:求4的平方根
SQL> select sqrt(4) from dual;
显示的结果:
SQRT(4)
----------
2
日期函数:Oracle 中的日期型数据实际含有两个值: 日期和时间。默认的日期格式是 DD-MON-RR.日期时间函数用来返回当前系统的日期和时间、以及对日期和时间类型的数据进行处理运算。
A、sysdate();获取系统的当前日期
例如:
SQL> select sysdate from dual;
显示的结果是:
SYSDATE
-----------
2011-4-8 13
B、current_timestamp();获取当前的时间和日期值
例如:
SQL> select current_timestamp from dual;
显示的结果是:
CURRENT_TIMESTAMP
--------------------------------------------------------------------------------
08-4月 -11 01.38.27.546000 下午 +08:00
C、add_months(date,count):在指定的日期上增加count个月
例如:输出当前时间的加上3个月的后的时间
SQL> select add_months(sysdate,3) from dual;
显示结果:
ADD_MONTHS(SYSDATE,3)
---------------------
2011-7-8 13:43:06
D、last_day(date);返回日期date所在月的最后一天
例如:
SQL> select sysdate,last_day(sysdate) from dual;
显示结果:
SYSDATE LAST_DAY(SYSDATE)
----------- -----------------
2011-4-8 13 2011-4-30 13:51:2
E、months_between(date1,dates);返回date1到date2之间间隔多少个月
例如:
SQL> select sysdate,months_between(sysdate,add_months(sysdate,3)) from dual;
显示结果:
SYSDATE MONTHS_BETWEEN(SYSDATE,ADD_MON
----------- ------------------------------
2011-4-8 13 -3
F、new_time(date,'this','other');将时间date从this时区转换成other时区
例如:
SQL> select sysdate,new_time(sysdate,'GMT','AST') from dual;
显示结果:
SYSDATE NEW_TIME(SYSDATE,'GMT','AST')
----------- -----------------------------
2011-4-8 13 2011-4-8 9:
G、next_day(day,'week');返回指定日期或最后一的第一个星期几的日期,这里day为星期几
例如:
SQL> select sysdate,next_day(sysdate,'星期五') from dual;
显示结果:
SYSDATE NEXT_DAY(SYSDATE,'星期五')
----------- --------------------------
2011-4-8 13 2011-4-15 13:53:10
H、round(参数,截取类型):日期的四舍五入
例如:四舍五入当前时间年
SQL> select sysdate,round(sysdate,'yyyy') from dual;
显示结果:
SYSDATE ROUND(SYSDATE,'YYYY')
----------- ---------------------
2011-4-9 22 2011-1-1
例如:四舍五入当前时间月
SQL> select sysdate,round(sysdate,'mm') from dual;
显示结果:
SYSDATE ROUND(SYSDATE,'MM')
----------- -------------------
2011-4-9 22 2011-4-1
例如:四舍五入当前时间日
SQL> select sysdate,round(sysdate,'dd') from dual;
显示的结果:
SYSDATE ROUND(SYSDATE,'DD')
----------- -------------------
2011-4-9 22 2011-4-10
I、to_char(参数,转换的类型): 日期的截取
例如:截取当前时间的年
SQL> select sysdate,to_char(sysdate,'yyyy') from dual;
显示结果:
SYSDATE TO_CHAR(SYSDATE,'YYYY')
----------- -----------------------
2011-4-9 22 2011
例如:截取当前时间的月
SQL> select sysdate,to_char(sysdate,'mm') from dual;
显示结果:
SYSDATE TO_CHAR(SYSDATE,'MM')
----------- ---------------------
2011-4-9 22 04
例如:截取当前时间的日
SQL> select sysdate,to_char(sysdate,'dd') from dual;
显示结果:
SYSDATE TO_CHAR(SYSDATE,'DD')
----------- ---------------------
2011-4-9 22 09
日期的数学运算:
在日期上加上或减去一个数字结果仍为日期。
两个日期相减返回日期之间相差的天数。
可以用数字除24来向日期中加上或减去小时
通用函数
这些函数适用于任何数据类型,同时也适用于空值:
A、NVL (expr1, expr2):如果expr1为空的话,显示expr2
例如:查看emp如奖金comm为空的话,替换成0
SQL> select empno,ename,job,mgr,hiredate,sal,nvl(comm,0),deptno from emp;
显示结果:
EMPNO ENAME JOB MGR HIREDATE SAL NVL(COMM,0) DEPTNO
----- ---------- --------- ----- ----------- --------- ----------- ------
7369 SMITH CLERK 7902 1980-12-17 800.00 0 20
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300 30
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500 30
7566 JONES MANAGER 7839 1981-4-2 2975.00 0 20
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400 30
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 0 30
7782 CLARK MANAGER 7839 1981-6-9 2450.00 0 10
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 0 20
7839 KING PRESIDENT 1981-11-17 5000.00 0 10
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0 30
7876 ADAMS CLERK 7788 1983-1-12 1100.00 0 20
7900 JAMES CLERK 7698 1981-12-3 950.00 0 30
7902 FORD ANALYST 7566 1981-12-3 3000.00 0 20
7934 MILLER CLERK 7782 1982-1-23 1300.00 0 10
14 rows selected
B、NVL2 (expr1, expr2, expr3):如果expr1为不空的话,显示expr2,如果expr1为空的话,显示expr3
例如:查找员工的编号是7521的员工的工资,如果奖金(comm)不为空的话,显示工资加奖金
SQL> select sal,nvl2(comm,sal+comm,sal) from emp where empno=7521;
显示结果:
SAL NVL2(COMM,SAL+COMM,SAL)
--------- -----------------------
1250.00 1750
C、NULLIF (expr1, expr2):expr1与expr2相等返回NULL,不等返回expr1
例如:查看员工7788的薪水和奖金,如果薪水和奖金相等的话返回null,否则返回工资
SQL> select sal,comm,nullif(sal,comm) from emp where empno=7788;
显示结果:
SAL COMM NULLIF(SAL,COMM)
--------- --------- ----------------
3000.00 3000
D、COALESCE (expr1, expr2, ..., exprn):如果第一个表达式为空,则返回下一个表达式。COALESCE 与 NVL 相比的优点在于 COALESCE 可以同时处理交替的多个值
例如:在emp表中测试的
为了测试,向emp表中添加一条记录:
SQL> insert into emp(empno,ename,deptno) values(7978,'guo',10);
测试语句:
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno,coalesce(comm,sal,1000) as "测试结果" from emp;
显示结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO 测试结果
----- ---------- --------- ----- ----------- --------- --------- ------ ----------
7369 SMITH CLERK 7902 1980-12-17 800.00 20 800
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30 300
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30 500
7566 JONES MANAGER 7839 1981-4-2 2975.00 20 2975
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30 1400
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30 2850
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10 2450
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20 3000
7839 KING PRESIDENT 1981-11-17 5000.00 10 5000
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30 0
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20 1100
7900 JAMES CLERK 7698 1981-12-3 950.00 30 950
7902 FORD ANALYST 7566 1981-12-3 3000.00 20 3000
7934 MILLER CLERK 7782 1982-1-23 1300.00 10 1300
7978 guo 10 1000
15 rows selected
组合函数:
分组函数作用于一组数据,并对一组数据返回一个值。
A、AVG(字段名):求该字段的平均值
例如:求出emp表中工资的平均值
SQL> select avg(nvl(sal,0)) from emp;
显示结果:
AVG(NVL(SAL,0))
---------------
1935
B、COUNT(字段名):求该字段中的总记录
例如:查询emp表中有几条记录
SQL> select count(*) from emp;
显示结果:
COUNT(*)
----------
15
C、MAX(字段名):求该字段的最大值
例如:求出emp表中的最高的工资的员工
SQL> select max(nvl(sal,0)) from emp;
显示结果:
MAX(NVL(SAL,0))
---------------
5000
D、MIN(字段名):求该字段的最小值
例如:求出emp表中的最低的工资的员工
SQL> select min(nvl(sal,0)) from emp;
显示结果:
MIN(NVL(SAL,0))
---------------
0
E、SUM(字段名):求该字段的和
例如:求emp一个需要发多少工资
SQL> select sum(sal)+sum(comm) as "总工资" from emp;
显示结果:
MIN(NVL(SAL,0))
---------------
0
非法使用组函数
A、所用包含于SELECT 列表中,而未包含于组函数中的列都必须包含于 GROUP BY 子句中。
例如:
SQL> select empno,count(job) from emp;
正确写法如下:
SQL> select empno,count(job) from emp group by empno;
B、不能在 WHERE 子句中使用组函数(注意)。
例如:SQL> select deptno from emp where count(job)>0 group by deptno;
备注:ORA-00934: 此处不允许使用分组函数
group by 语句
如果在查询的过程中需要按某一列的值进行分组,以统计该组内数据的信息时,就要使用group by子句。不管select是否使用了where子句都可以使用group by子句。
注意:group by子句一定要与分组函数结合使用,否则没有意义。
求出每个部门的员工的数
SQL> select count(*) from emp group by deptno;
显示的结果:
COUNT(*)
----------
6
5
4
求每个部门的中员工的平均工资
SQL> select avg(nvl(sal,0)) from emp group by deptno;
显示的结果:
AVG(NVL(SAL,0))
---------------
1566.6666666666
2175
2187.5
Having子句
HAVING 子句对 GROUP BY 子句设置条件的方式与 WHERE 子句和 SELECT 语句交互的方式类似。WHERE 子句搜索条件在进行分组操作之前应用;而 HAVING 搜索条件在进行分组操作之后应用。HAVING 语法与 WHERE 语法类似,但 HAVING 可以包含聚合函数。HAVING 子句可以引用选择列表中出现的任意项。
备注:having子句通常与group by子句结合使用
语法:
SELECT column, group_function
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[HAVING group_condition]
[ORDER BY column];
A、查询部门的员工人数大于五部门编号
SQL> select deptno,count(*) from emp group by deptno having count(*)>5;
显示结果:
DEPTNO COUNT(*)
------ ----------
30 6
备注:分组函数可以嵌套
Order by语句
ORDER BY 子句在SELECT语句的结尾。使用 ORDER BY 子句排序 :ASC(ascend): 升序 ;DESC(descend): 降序 。默认的是ASC升序
查询员工信息按照部门的编号进行升序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by empno;
或:
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by empno asc;
显示的结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7369 SMITH CLERK 7902 1980-12-17 800.00 20
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30
7566 JONES MANAGER 7839 1981-4-2 2975.00 20
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
7839 KING PRESIDENT 1981-11-17 5000.00 10
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20
7900 JAMES CLERK 7698 1981-12-3 950.00 30
7902 FORD ANALYST 7566 1981-12-3 3000.00 20
7934 MILLER CLERK 7782 1982-1-23 1300.00 10
7978 guo 10
15 rows selected
查询员工信息按照部门的编号进行降序排列
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by empno desc;
显示的结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7978 guo 10
7934 MILLER CLERK 7782 1982-1-23 1300.00 10
7902 FORD ANALYST 7566 1981-12-3 3000.00 20
7900 JAMES CLERK 7698 1981-12-3 950.00 30
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30
7839 KING PRESIDENT 1981-11-17 5000.00 10
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30
7566 JONES MANAGER 7839 1981-4-2 2975.00 20
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30
7369 SMITH CLERK 7902 1980-12-17 800.00 20
15 rows selected
按部门升序,员工编号降序查询
SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp order by deptno asc,empno desc;
显示的结果:
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7978 guo 10
7934 MILLER CLERK 7782 1982-1-23 1300.00 10
7839 KING PRESIDENT 1981-11-17 5000.00 10
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10
7902 FORD ANALYST 7566 1981-12-3 3000.00 20
7876 ADAMS CLERK 7788 1983-1-12 1100.00 20
7788 SCOTT ANALYST 7566 1982-12-9 3000.00 20
7566 JONES MANAGER 7839 1981-4-2 2975.00 20
7369 SMITH CLERK 7902 1980-12-17 800.00 20
7900 JAMES CLERK 7698 1981-12-3 950.00 30
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30
15 rows selected
相关推荐
本教程将详细讲解SQL的基本使用方法,包括基础语法、常用的SQL指令、数据筛选、函数应用、数据表操作、高级查询技巧以及SQL语法的具体应用实例。 基础语法方面,SQL语句一般由关键字、表名、列名和条件表达式等组成...
### 超全SQL语句大全(葵花宝典) ...总结,本篇“超全SQL语句大全”涵盖了从基础到高级的SQL操作,旨在帮助读者快速掌握和应用SQL语言进行数据管理。无论是初学者还是有经验的开发人员,都能从中找到有用的参考资料。
### 超详细Oracle教程知识点总结 #### 一、引言 - **SUN与Oracle合并背景**:2009年,Oracle宣布以74亿美元收购SUN Microsystems,此举被视为Oracle迈向云计算的重要一步。 - **云计算核心价值**:随着云计算在企业...
### 超级简单的SQL21天...在第一周的学习中,我们重点介绍了SQL的基础知识、常用语法、函数以及如何使用`SELECT`语句进行数据查询。接下来的几周将继续深入学习更多的高级主题和技术细节,帮助读者更全面地掌握SQL。
以下是对标题和描述中提到的Oracle常用知识点的详细说明: 1. **用户管理**: - **SYS**:Oracle在安装时会自动生成SYS用户,这是一个超级用户,拥有最高的权限,包括sysDBA角色,可以创建数据库。默认密码通常在...
根据给定的信息,我们可以归纳出一系列关于SQL语言的关键知识点,主要涵盖了数据库的创建与管理、表的创建与修改、视图的使用以及查询操作等...以上就是从提供的内容中总结出的一些关键SQL知识点,希望能对你有所帮助。
### 超详细Oracle教程知识点总结 #### 一、引言 - **Oracle与SUN合并背景**:2009年,Oracle宣布以74亿美元收购SUN Microsystems,此举被视为Oracle迈向云计算的重要一步。 - **云计算核心价值**:随着云计算在企业...
下面是 Excel 中常用函数的总结: 数学和三角函数 * MOD:返回除法运算的余数 * ROUND:将数字舍入到指定的位数 * INT:将数字舍入到最接近的整数 * TRUNC:将数字截断到指定的位数 * RANK:返回一个数字在某个...
### 超详细的Oracle教程知识点总结 #### 一、Sun与Oracle合并对未来的影响 1. **数据成为云计算核心**: - 数据是云计算的核心组成部分,而数据库技术则是支撑这一核心的关键。 - 随着云计算对企业的重要性日益...
### Java开发常用单词总结 #### 一、Java基础词汇 - **JDK(Java Development Kit)**:Java开发工具包,包含编译、运行Java程序所需的所有工具。 - **JVM(Java Virtual Machine)**:Java虚拟机,是执行Java字节码的...
以上内容覆盖了Oracle数据库的基础管理和操作,以及一些常用的SQL*Plus命令。这些知识点对于初级程序员来说非常重要,能够帮助他们更快地入门Oracle数据库技术,并在实际工作中有效地利用Oracle的强大功能。希望每位...
### 超详细Oracle教程知识点总结 #### 一、引言 - **Oracle与SUN合并背景**:2009年,Oracle以74亿美元收购SUN Microsystems,这一举动标志着Oracle进入了硬件市场,并获得了MySQL数据库的所有权。此次收购不仅加强...
本部分将介绍SQL语言的基本概念和常用操作,包括数据查询、数据插入、数据更新、数据删除等,以及如何使用SQL进行数据分析。 ### 第八部分 数据挖掘案例分析 #### 案例一 AJourneythroughTitanic597c770e 本案例...
### 超详细Oracle教程知识点总结 #### 一、引言 本教程旨在全面介绍Oracle数据库的管理和使用方法,覆盖了从基础知识到高级主题的各个方面。Oracle作为一种广泛应用于企业级应用的强大关系型数据库管理系统(RDBMS...
综上所述,文档“常用数据挖掘算法总结及Python实现”提供了数据挖掘算法从理论到实践的全面知识,涵盖了数据挖掘的基本概念、核心算法、Python实现以及真实案例分析,为数据挖掘初学者提供了深入理解并应用相关算法...
### 学习笔记之Oracle教程知识点总结 #### 引言 - **SUN与Oracle合并背景及意义**: - **并购概述**:2009年4月,Oracle以74亿美元收购SUN,这一举措标志着Oracle进一步扩展其在数据库领域的领导地位,并通过整合...