设为首页 收藏本站
查看: 731|回复: 0

[经验分享] Oracle学习 sql基本语法(一)

[复制链接]

尚未签到

发表于 2016-7-27 08:27:47 | 显示全部楼层 |阅读模式
  oracle sql语句
-----------sql*plus命令---------------------

该变用户一般有两种方法:
   1.退出当前用户   exit
   2.切换用户   connect 用户名/密码
    connect / as sysdba  切换成超级用户
    通常简写:conn /as sysdba
查看当前用户  
    show user
设置行宽  set linesize 150  默认为80
查看行宽  show linesize
 
  / 执行上一条sql语句
  
设置页面大小  set pagesize 100
查看页面大小  show pagesize

   显示参数的值:
      show 参数值
  
 select * from tab; 查看当前有多少表
 
 注释:
     单行--
     多行/* */

desc 表名  显示表的结构
--------------
scoot用户的表
dept表:  
emp表
清屏  windos中: host cls
        linux: host clear
设置某一列的大小
     column job format a15  字符形式 / col job for a15
     column sal format 9999 数字形式  / col sal for 9999
     对于字符串: a20 ,20表示一个数据,有20个字符的宽度
     对于数字: 9表示一位,有几位数就是最多显示几位
--------------

空值的处理:
     不是一个有效的值,不是0 ,也不是空字符串
     所以不能这样写: 某列  !=null   
     正确写法: ename is not null
     含有null的表达式结果为空
  
edit 修改上一条sql语句;ed[it]  注意: 修改里面的sql语句时不用使用分号
滤空函数:
 nvl(表达式,当表达式为空值时使用的值)

 select empno ,ename,sal,sal*12 as 年薪 ,nvl(comm,0) 奖金,(sal*12+nvl(comm,0) )总收入 from emp
 
=====================

对字符串的处理:
 
  是区分大小写的,在使用时要加引号
  在制定别名时,引号可以加,也可以不加,
  当含有空格,特殊字符时,一定要加引号。
  不加引号时,显示都为大写。加上一号后,按自己写的显示;
 
  在使用字符串时,使用单引号,使用别名的时候用双引号;

 distinct 去掉重复值
      作用于一个列:    select  distinct job from emp;
      作用于多个列 ,所有列的值重复才算重复的记录
                  : select distinct job,ename from emp;

   如果只查询一个表达式,没用到任何表的数据,这时也必须写from子句;
   可以写成from dual
   dual 是oracle提供的一个虚表,本身存在,可以直接使用;

    如: select 3+2 from dual;
        select 'hello' || 'world' from dual;
    也可以使用concat函数;
          select concat('hello','world') from dual;

 
-----------------------

like
   在使用like时,可以使用%与_,分别表示任意数量的任意字符或任意一个字符,
   要想表达%或_本身,需要使用转义符,例:
  select * from emp where ename like "KI\%%" escape '\';

between  and :

select *from emp where sal between 3000 and 4000;(前面是小值,后面是大值,否则没有结果)


or 和in:
select *from emp where empno=7369 or empno=7654 or empno=7934

 select *from emp where empno in(7369,7654,7934);


in

   where ..in (...,.....,....) 如果含有null,没有影响。
  例如: 查询所有事经理的员工
     select *from emp where empno in (select mgr from emp);

  where ...not in (....,...,...) 如果含有null,则不返回任何结果
     例如查询所有的不是经理员工
      select *from emp where empno not in (select mgr from emp where mgr is not null);

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-249936-1-1.html 上篇帖子: sqoop导出hive数据到oracle 下篇帖子: Oracle 触发器介绍和使用示例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表