oracle复习(二)

十一、replace 替换
格式:(原字符串,要查找的字符或字符串,替换的字符或字符串)
select replace(‘hello world‘,‘o‘,‘a‘) from dual; //替换时区分大小写
select e.empno,replace(e.ename,‘S‘,‘J‘) from emp e;
十二、去除空格的函数
trim 去除字符串2边的空格
ltrim 去除字符串左边的空格 (left)
rtrim 去除字符串右边的空格 (right)

十三、日期类型
to_date:(把字符串转换成日期的函数)
to_date(要转换成日期的字符串, 转换格式)
select to_date(‘2017-04-20 14:30:12‘,‘yyyy-mm-dd HH24:mi:ss‘) from dual;
to_char() (可以把日期或数字转换成字符串)
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss:SSSS‘) from dual;
select to_char(1234.5, ‘$9999D9‘) from dual;

--查询今天是今年的多少天
select to_char(sysdate, ‘DDD‘) from dual;
--查询当月的多少天
select to_char(sysdate, ‘DD‘) from dual;
--查询这个星期的第多少天
select to_char(sysdate, ‘D‘) from dual;

to_number--把字符数字 转换成数字

计算2个日期之间相差的天数
select trunc(sysdate-hiredate) from dual;
--当前日期前5年的时间
select sysdate, sysdate - interval ‘5‘ year from dual;
--当前日期前5个月的日期
select sysdate, sysdate - interval ‘5‘ month from dual;

months_between 返回2个日期之间相差的月数

add_months --在一个日期基础上增加若干个月
select add_months(sysdate, 2) from dual;
select add_months(sysdate, -2) from dual;
last_day--返回当月的最后一天
select to_char(last_day(sysdate), ‘yyyy-mm-dd‘) from dual;

十四、查询记录总数
select count(*) from 表名
select count(*) from emp;
select count(1) from emp;
select count(comm) from emp; //只会统计comm != null 的 记录
1.求最大工资的员工
select max(sal) from emp where sal is not null;
2:求最小值的数据
select min(列名) from 表名
3:求和
select sum(列名) from 表名
4:求平均值
select avg(列名) from 表名
5.连合查询,求值的字段必须是数值类型的字段
select avg(sal),sum(sal),max(sal),min(sal) from emp;

6:分组查询
--查询出每个部门的平均工资(按部门分组)
select floor(avg(sal)),deptno from emp group by deptno;
--查询每个部门的总工资和,平均工资,最高工资
select floor(avg(sal)) as 平均工资,sum(sal) 总工资, max(sal) 最高工资,deptno from emp group by deptno;
--查询每个部门,每个工作的总工资和
select sum(sal) 总工资, deptno, job from emp group by deptno,job
--查询出每个部门,每个工种的总人数
select count(1),deptno,job from emp group by deptno,job;
--查询每个部门的员工数
select count(1),deptno from emp group by deptno;

十五、列的操作
1.新增列
ALTER TABLE (表名) ADD (列名 数据类型);
alter table t_test add tname nvarchar2(20);

2.改某个表某个列的数据类型
ALTER TABLE (表名) MODIFY (列名 数据类型);
alter table t_test modify tname nvarchar2(20);

3.更改列名
ALTER TABLE (表名) RENAME COLUMN (当前列名) TO (新列名); /////不需要括号
alter table t_test rename COLUMN tname to tname2

4.删除某列
ALTER TABLE (表名) DROP COLUMN (列名);
alter table t_test drop COLUMN tname2

5.重命名表名
ALTER TABLE (当前表名) RENAME TO (新表名);
alter table t_test rename to t_test2;

时间: 2024-10-16 08:29:05

oracle复习(二)的相关文章

Oracle学习(二):过滤和排序

1.知识点:可以对照下面的录屏进行阅读 SQL> --字符串大小写敏感 SQL> --查询名叫KING的员工信息 SQL> select * 2 from emp 3 where ename = 'KING'; SQL> --日期格式敏感 SQL> --查询入职日期为17-11月-81的员工 SQL> select * 2 from emp 3 where hiredate='17-11月-81'; --正确例子 SQL> ed 已写入 file afiedt.b

Hibernate复习(二)主要对象

1.SessionFactory 一个SessionFactory实例对应一个数据存储源,应用从SessionFactory中获得Session实例. SessionFactory有以下特点: –它是线程安全的,这意味着它的同一个实例可以被应用的多个线程共享. –它是重量级的,这意味着不能随意创建或销毁它的实例.如果应用只访问一个数据库,只需要创建一个SessionFactory实例,在应用初始化的时候创建该实 例.如果应用同时访问多个数据库,则需要为每个数据库创建一个单独的SessionFac

高二上学期期末―一轮复习二次(11.9-1.15)

目标:班级第一 继期中考试的一轮一次后,一轮复习二次需要完成的有:(不包括真题试卷) 数学 一年好题刷完一本 圆锥曲线刷完 自招秘籍刷完 浙大一试刷某些薄弱专题 物理 高考必刷题刷完 化学 考点124 53刷完 一年好题刷完 生物 考点13 一年好题刷完 高考必刷题刷完 原文地址:https://www.cnblogs.com/fangshun2002/p/9787909.html

Oracle复习笔记

/*----------------------------------------常用命令(sqlplus环境)----------------------------------------*/ conn scott/[email protected] [as sysdba] || [as sysoper] --切换用户 show user --当前用户 passw[ord] --修改密码 disc --断开连接 clear scr --清屏 start || @ --运行sql脚本 edi

Oracle笔记二

一.数据库语言分类  二.DML之数据插入 把一个表中的数据查询出来插入另外一个表中. create table student(id number,name varchar2(20),age number); insert into student select id,name,age from student1; insert into student select * from student as of timestamp(sysdate-5/1440);          sysdat

Oracle闲扯<二>

数据冗余和数据不一致性是数据库的源头!一个万能的答案. ---老牛 SQL简介 SQL Statement (SQL 语句) 1)DDL Data Defination Language数据库定义语言 用于定义数据库的三级结构,包括外模式.概念模式.内模式及其相互之间的映像,定义数据的完整性.安全控制等约束,不需要commit CREATE Ps:例如创建用户 create user Super_YY identified by 123:又如create table创建一张表 ALTER Ps:

【oracle】二、基本的select语句

一.select 基本语法: SELECT *|{[DISTINCT] column|expression [alias],...} FROM table; SELECT 标识 选择哪些列. FROM 标识从哪个表中选择. 1.从表中取出所有列 select * from emp; Connected to Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 Connected as c##[email protected] SQL

Oracle【二维表管理:约束】

1.简单的表创建和字段类型最简单的方式去创建表(没有添加主键之类的约束条件)[Oracle的字段类型]number:数值类型--整数类型:number(a) 总长度a--小数类型:number(a,b) 总长度a,小数长度b,小数可缺省varchar2:字符类型--字符类型 varchar2(ln) ln表示字符的最大长度,实际存储内存的长度<=ln--特点:多态分配存储空间,节省空间char:字符类型--字符类型char(ln) 不管字符数据长度多大,直接在内存开辟ln大小的空间存储数据--特

Oracle连接&lt;二&gt;

3. 外连接 外连接是指在内连接的基础上,将某个连接表中不符合连接条件的记录加入结果集.根据结果集中所包含不符合连接条件的记录来源的不同,外连接分为左外连接.右外连接.全外连接3中. (1)左外连接 左外连接是指在内连接的基础上,将连接操作符左侧表中不符合连接条件的记录加入结果集中,与之对应的连接操作符右侧列表用NULL填充. 在Oracle数据库,左外连接的表示方式有两种. 标准SQL语句的连接方式 SELECT table1.column,table2.column[,...] FROM t