2.1 Oracle之DML的SQL语句之单表查询以及函数
1.SQL简介
对于不同的数据库来说,SQL语句是相通的,关系型数据库都以SQL语句为操作的标准,只是相应的数据库对应的函数不相同。
SQL(Structured Query Language,结构化查询语言)是功能强大的数据库语言,用于·数据库通讯。
1.2SQL的功能
SQL 的功能可分为以下三组
DML (Data Manipulation Language,数据操纵语言)用于查询和更改数据
DDL (Data Definition Language ,数据定义语言)用于定义数据的结构,创建,修改,删除数据库对象
DCL (Data Control Language,数据库控制语言)用于定义数据库权限
2.单表sql的查询语句(很实用)
大体结构:select [字段|* as 别名] from [表名] where [条件 and|or]
1.需要注意distinct 消除重复行 SELECT DISTINCT empno,job FROM emp ;
2.用||连接显示信息 SELECT '编号是 ' || empno || '姓名是 ' || ename || '工作是 ' || job FROM emp ;
3.可以做四则运算 求出年收入:SELECT ename , sal * 12 income FROM emp ;
4.条件查询的where子句
重点的条件IS NOT NULL和 IS NULL 查询有佣金的人 : SELECT * FROM emp WHERE comm IS NOT NULL ;
有两个条件时用AND(和|且)或者OR(或|并)连接 基本工资大于1500和有奖金的员工 :SELECT * FROM emp WHERE sal>1500 AND comm IS NOT NULL ;
NOT()表整体相反 基本工资不大于1500和没有奖金的员工 :SELECT * FROM emp WHERE NOT( sal>1500 AND comm IS NOT NULL) ;
BETWEEN 小值|‘日期加单引号 ’ and 大值
查询工资在1500到2000的员工 :SELECT * FROM emp WHERE sal>1500 AND sal<3000 = SELECT * FROM emp WHERE sal BETWEEN 1500 AND 3000 ;
单引号括字符信息必须大小写正确 查询名字是SMITH的员工:SELECT * FROM emp WHERE ename='SMITH' ;
使用字段IN|NOT IN()表同一字段的多条件查询 (数值和字符串都可以)
查询部门号为7369,7499,7521的员工信息:SELECT * FROM emp WHERE empno IN (7369,7499,7521) ;
LIKE的模糊查询(可查日期加单引号) 注意_表一个未知字符,%表0个或多个未知字符
查询第二个名字带M的员工:SELECT * FROM emp WHERE ename LIKE '_M%' ;
<> != 表示不等于 查询不是7396的员工信息: SELECT * FROM emp WHERE empno<>7369 ;
5.对结果进行排序(ORDER BY 排序)
SELECT {DISTINCT} * | FROM {WHERE (s)} {ORDER BY 1, 2 ASC|DESC} ASC表升序 DESC表降序(默认)
注意下第一排序和第二排序的区别 :在第一排序相同情况下进行第二排序
6.函数相关(重要)
单行函数:function_name 函数名(column列名|expression表达式,[arg1,arg2,…参数])
0.1字符函数:UPPER(转大写),LOWER(转小写)、initcap()首大写、||连接CONCAT('hello ','world')、substr('hello',1,3)截取、length('hello')长度、replace('hello','l','x')替换
0.2数值函数:ROUND(789.536,2)四舍五入、TRUNC()截断、MOD取余、
0.3 SYSDATE 当前日期、ROUND((SYSDATE-hiredate)/7)求之前星期数
eg:to_date('2018-10-01','yyyy-MM-dd') 、ROUND(sysdate) 取当前不带日期
eg:to_char(fa.last_update_date,'yyyy-mm-dd')>'2018-10-10'
0.4 转换函数TO_CHAR() 换成字符、TO_NUMBER()换成数字、TO_DATE()换成日期、TO_CHAR(hiredate,'yyyy-mm-dd')
0.5 通用函数 四则运算、(sal+NVL(comm,0))*12字段默认给指定数值
IF…ELSEIF…ELSE = DECODE()
SELECT DECODE(1,1,' 结果是1',2,' 结果时2',3,' 结果是3') FROM DUAL ;
2.1 Oracle之DML的SQL语句之单表查询以及函数的更多相关文章
- 2.2 Oracle之DML的SQL语句之多表查询以及组函数
一.SQL的多表查询: 1.左连接和右连接(不重要一方加(+)) SELECT e.empno,e.ename,d.deptno,d.dname,d.loc FROM emp e,dept d WHE ...
- SQL语句 自连表查询。inner join用法,partition by ,列转行查询
use mydb1 go -- 表T_Employee2 -- Id Name Position Dept -- 1 张三 员工 市场部 -- 2 李四 经理 销售部 -- 3 王五 经理 市场部 - ...
- 惊世骇俗的sql语句之连表查询
select `product_skus`.id as skuId, `wname` as sku名称, if(`sku_attributes`.`status`=1,'上架','下架') as 状态 ...
- SQL Merge 语法 单表查询
--项目中需要用到Merg语法,于是去网上查了资料,发现竟然都是多表查询,问题是我只有一张表,于是我纳闷了,后来我灵机一动,就搞定了!--表名:t_login(登录表)--字段:f_userName( ...
- sql多表查询(单表查询略过)
表library: 表borrow: 表reader: 1.等值连接:(常用) 原理:将多张表组合成一个逻辑大表,即字段相加记录相乘(笛卡尔积). 语法:select * from 表A,表B whe ...
- 查询Oracle正在执行的sql语句
--查询Oracle正在执行的sql语句及执行该语句的用户 SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, ...
- oracle 监控执行的sql语句
oracle 监控执行的sql语句 select * from v$sqlarea a where module='PL/SQL Developer' order by a.FIRST_LOAD_TI ...
- Oracle数据库常用的Sql语句整理
Oracle数据库常用的Sql语句整理 查看当前用户的缺省表空间 : select username,default_tablespace from user_users; 2.查看用户下所有的表 : ...
- Oracle中,利用sql语句中的函数实现保留两位小数和四舍五入保留两位小数
Oracle中,利用sql语句中的函数实现保留两位小数和四舍五入保留两位小数: select trunc(1.23856789,2) from dual round(m,n) 可以四舍五入 trunc ...
随机推荐
- Python 有用的 map() deduce() filter() 函数
#!/usr/bin/python#5!+4!+3!+2!+1! #give 3 return 3*2*1def jiechen(n): N = map(lambda x:x+1,range(n)) ...
- 404 Note Found 队-Alpha9
目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示 ...
- ORA-10485: Real-Time Query cannot be enabled while applying migration redo
情景:利用Dataguard滚动方式升级数据库后,备库应用redo报错:ORA-10485 MRP0: Background Media Recovery terminated with error ...
- async await循环请求
var sleep = function (item,time) { return new Promise(function (resolve, reject) { setTimeout(functi ...
- 前端基础-jQuery的内容之选择器
阅读目录 ID选择器 类选择器 元素选择器 通配符选择器 层级选择器 基本筛选器 内容筛选器 可见性筛选器 属性筛选器 子元素筛选器 表单元素筛选器 表单对象筛选器 this和$(this) 一.jQ ...
- IOT大数据大世界大未来,物联网产业大数据应用简析
在物联网时代,面对PB级的数据,企业将难以以一己之力完成基础设施的建设.物联网所产生的大量数据不仅会驱动现在的数据中心发生根本性的变化,同时也会驱动相关企业采用新的大数据策略. 物联网的价值在于数据: ...
- WOT干货大放送:大数据架构发展趋势及探索实践分享
WOT大数据处理技术分会场,PingCAP CTO黄东旭.易观智库CTO郭炜.Mob开发者服务平台技术副总监林荣波.宜信技术研发中心高级架构师王东及商助科技(99Click)顾问总监郑泉五位讲师, ...
- 树莓派3B+学习笔记:9、更改软件源
树莓派系统安装完成后,由于默认软件源服务器访问速度慢,安装软件耗时会很长,可以通过更改软件源来加快软件的安装速度. 系统安装完成后默认软件源如下: 更改镜像源前需要自行查找镜像源,并记下网址: 1.阿 ...
- markupsafe._compat出错的解决办法
在windows下用pip进行安装的flask和freeze会在运行程序的时候出现报错 markupsafe._compat出错,那么此时找到对应的pip文件夹下自己创建一个_compat.py 然后 ...
- 20155227 2016-2017-2《Java程序设计》课程总结
20155227 2016-2017-2<Java程序设计>课程总结 (按顺序)每周作业链接汇总 预备作业1:我眼中的师生关系. 预备作业2:一些简单的C语言知识回顾,并总结之前一些成功的 ...