Oracle之SQL基础

  1. 检查Oracle安装
  2. 首先,以超级管理员的身份登录oracle   
  3.     sqlplus sys/bjsxt as sysdba   
  4.   
  5. 然后,解除对scott用户的锁   
  6.     alter user scott account unlock;   
  7. 那么这个用户名就能使用了。   
  8. (默认全局数据库名orcl)   
  9.   
  10. 1、select ename, sal 12 from emp; //计算年薪   
  11. 2、select 2*3 from dual;  //计算一个比较纯的数据用dual表   
  12. 3、select sysdate from dual;  //查看当前的系统时间   
  13. 4、select ename, sal*12 anuual_sal from emp; //给搜索字段更改名称(双引号 keepFormat 别名有特殊字符,要加双引号)。   
  14. 5、任何含有空值的数学表达式,最后的计算结果都是空值。   
  15. 6、select ename||sal from emp;  //(将sal的查询结果转化为字符串,与ename连接到一起,相当于Java中的字符串连接)   
  16. 7、select ename||'afasjkj' from emp;   //字符串的连接   
  17. 8、select distinct deptno from emp;   //消除deptno字段重复的值   
  18. 9、select distinct deptno job from emp; //将与这两个字段都重复的值去掉   
  19. 10、select from emp where deptno=10  //(条件过滤查询)   
  20. 11、select from emp where empno 10 //大于 过滤判断   
  21. 12、select from emp where empno <> 10  //不等于  过滤判断   
  22. 13、select from emp where ename 'cba' //字符串比较,实际上比较的是每个字符的AscII值,与在Java中字符串的比较是一样的   
  23. 14、select ename, sal from emp where sal between 800 and 1500 //(between and过滤,包含800 1500)   
  24. 15、select ename, sal, comm from emp where comm is null //(选择comm字段为null的数据)   
  25. 16、select ename, sal, comm from emp where comm is not null //(选择comm字段不为null的数据)   
  26. 17、select ename, sal, comm from emp where sal in (8001500,2000);  //(in 表范围)   
  27. 18、select ename, sal, hiredate from emp where hiredate '02-2月-1981'//(只能按照规定的格式写)   
  28. 19、select ename, sal from emp where deptno =10 or sal >1000;   
  29. 20、select ename, sal from emp where deptno =10 and sal >1000;   
  30. 21、select ename, sal, comm from emp where sal not in (8001500,2000);  //(可以对in指定的条件进行取反)   
  31. 22、select ename from emp where ename like '%ALL%'  //(模糊查询)   
  32. 23、select ename from emp where ename like '_A%'   //(取第二个字母是A的所有字段)   
  33. 24、select ename from emp where ename like '%/%%'  //(用转义字符/查询字段中本身就带%字段的)   
  34. 25、select ename from emp where ename like '%$%%' escape '$'  //(用转义字符/查询字段中本身就带%字段的)   
  35. 26、select from dept order by deptno desc; (使用order by  desc字段 对数据进行降序排列 默认为升序asc);   
  36. 27、select from dept where deptno <>10 order by deptno asc;   //(我们可以将过滤以后的数据再进行排序)     
  37. 28、select ename, sal, deptno from emp order by deptno asc, ename desc;   //(按照多个字段排序 首先按照deptno升序排列,当detpno相同时,内部再按照ename的降序排列)   
  38. 29、select lower(ename) from emp;  //(函数lower() 将ename搜索出来后全部转化为小写);   
  39. 30、select ename from emp where lower(ename) like '_a%' //(首先将所搜索字段转化为小写,然后判断第二个字母是不是a)   
  40. 31、select substr(ename, 23from emp;    //(使用函数substr() 将搜素出来的ename字段从第二个字母开始截,一共截3个字符)   
  41. 32、select chr(65from dual;  //(函数chr() 将数字转化为AscII中相对应的字符)    
  42. 33、select ascii('A'from dual;  //(函数ascii()与32中的chr()函数是相反的 将相应的字符转化为相应的Ascii编码)                                                                                                                                                                                                                                                                                                                                             )   
  43. 34、select round(23.232from dual;  //(函数round() 进行四舍五入操作)   
  44. 35、select round(23.2322from dual;  //(四舍五入后保留的小数位数 个位 -1 十位)   
  45. 36、select to_char(sal, '$99,999.9999')from emp;  //(加$符号加入千位分隔符,保留四位小数,没有的补零)   
  46. 37、select to_char(sal, 'L99,999.9999')from emp;  //(L 将货币转化为本地币种此处将显示¥人民币)   
  47. 38、select to_char(sal, 'L00,000.0000')from emp;  //(补零位数不一样,可到数据库执行查看)   
  48. 39、select to_char(hiredate, 'yyyy-MM-DD HH:MI:SS'from emp;  //(改变日期默认的显示格式)   
  49. 40、select to_char(sysdate, 'yyyy-MM-DD HH:MI:SS'from dual;  //(用12小时制显示当前的系统时间)   
  50. 41、select to_char(sysdate, 'yyyy-MM-DD HH24:MI:SS'from dual;  //(用24小时制显示当前的系统时间)   
  51. 42、select ename, hiredate from emp where hiredate to_date('1981-2-20 12:24:45','YYYY-MM-DD HH24:MI:SS');   //(函数to-date 查询公司在所给时间以后入职的人员)   
  52. 43、select sal from emp where sal to_number('$1,250.00''$9,999.99');   //(函数to_number()求出这种薪水里带有特殊符号的)   
  53. 44、select ename, sal*12  nvl(comm,0from emp;   //(函数nvl() 求出员工的"年薪 提成(或奖金)问题")   
  54. 45、select max(sal) from emp;  // (函数max() 求出emp表中sal字段的最大值)   
  55. 46、select min(sal) from emp;  // (函数max() 求出emp表中sal字段的最小值)   
  56. 47、select avg(sal) from emp;  //(avg()求平均薪水);   
  57. 48、select to_char(avg(sal), '999999.99'from emp;   //(将求出来的平均薪水只保留2位小数)   
  58. 49、select round(avg(sal), 2from emp;  //(将平均薪水四舍五入到小数点后2位)   
  59. 50、select sum(sal) from emp;  //(求出每个月要支付的总薪水)   
  60.   
  61. /组函数(共5个):将多个条件组合到一起最后只产生一个数据//min() max() avg() sum() count()/   
  62. 51、select count(*) from emp;  //求出表中一共有多少条记录   
  63. 52、select count(*) from emp where deptno=10 //再要求一共有多少条记录的时候,还可以在后面跟上限定条件   
  64. 53、select count(distinct deptno) from emp;   //统计部门编号前提是去掉重复的值   
  65. 聚组函数group by() //   
  66. 54、select deptno, avg(sal) from emp group by deptno;  //按照deptno分组,查看每个部门的平均工资   
  67. 55、select max(sal) from emp group by deptno, job; //分组的时候,还可以按照多个字段进行分组,两个字段不相同的为一组   
  68. 56、select ename from emp where sal (select max(sal) from emp); //求出   
  69. 57、select deptno, max(sal) from emp group by deptno; //搜素这个部门中薪水最高的的值   
  70. //having函数对于group by函数的过滤 不能用where//   
  71. 58、select deptno, avg(sal) from emp group by deptno having avg(sal) >2000(order by //求出每个部门的平均值,并且要 2000   
  72. 59、select avg(sal) from emp where sal >1200 group by deptno having avg(sal) >1500 order by avg(sal) desc;//求出sal>1200的平均值按照deptno分组,平均值要>1500最后按照sal的倒序排列   
  73. 60、select ename,sal from emp where sal (select avg(sal) from emp);  //求那些人的薪水是在平均薪水之上的。   
  74. 61、select ename, sal from emp join (select max(sal) max_sal ,deptno from emp group by deptno) on (emp.sal t.max_sal and emp.deptno=t.deptno);  //查询每个部门中工资最高的那个人   
  75. ///等值连接//   
  76. 62、select e1.ename, e2.ename from emp e1, emp e2 where e1.mgr e2.empno;  //自连接,把一张表当成两张表来用   
  77. 63、select ename, dname from emp, dept;  //92年语法 两张表的连接 笛卡尔积。   
  78. 64、select ename, dname from emp cross join dept; //99年语法 两张表的连接用cross join   
  79. 65、select ename, dname from emp, dept where emp.deptno dept.deptno; // 92年语法 表连接 条件连接   
  80. 66、select ename, dname from emp join dept on(emp.deptno dept.deptno); // 新语法   
  81. 67、select ename,dname from emp join dept using(deptno); //与66题的写法是一样的,但是不推荐使用using : 假设条件太多   
  82. ///非等值连接///   
  83. 68、select ename,grade from emp join salgrade on(e.sal between s.losal and s.hisal); //两张表的连接 此种写法比用where更清晰   
  84. 69、select ename, dname, grade from emp e   
  85.     join dept on(e.deptno d.deptno)   
  86.     join salgrade on (e.sal between s.losal and s.hisal)   
  87.     where ename not like '_A%' //三张表的连接   
  88. 70、select e1.ename, e2.ename from emp e1 join emp e2 on(e1.mgr e2.empno); //自连接第二种写法,同62   
  89. 71、select e1.ename, e2.ename from emp e1 left join emp e2 on(e1.mgr e2.empno); //左外连接 把左边没有满足条件的数据也取出来   
  90. 72、select ename, dname from emp right join dept on(e.deptno d.deptno); //右外连接   
  91. 73、select deptno, avg_sal, grade from (select deptno, avg(sal) avg_sal from emp group by deptno) join salgrade  on    (t.avg_sal between s.losal and s.hisal);//求每个部门平均薪水的等级   
  92. 74、select ename from emp where empno in (select mgr from emp); // 在表中搜索那些人是经理   
  93. 75、select sal from emp where sal not in(select distinct e1.sal from emp e1 join emp e2 on(e1.sal e2.sal)); // 面试题 不用组函数max()求薪水的最大值   
  94. 76、select deptno, max_sal from   
  95.     (select avg(sal) max_sal,deptno from emp group by deptno)   
  96.         where max_sal =   
  97.         (select max(max_sal) from   
  98.          (select avg(sal) max_sal,deptno from emp group by deptno)   
  99.     );//求平均薪水最高的部门名称和编号。   
  100. 77、select t1.deptno, grade, avg_sal from   
  101.       (select deptno, grade, avg_sal from   
  102.     (select deptno, avg(sal) avg_sal from emp group by deptno) t   
  103.         join salgrade on(t.avg_sal between s.losal and s.hisal)   
  104.       t1   
  105.     join dept on (t1.deptno dept.deptno)   
  106.     where t1.grade    
  107.       (   
  108.         select min(grade) from   
  109.           (select deptno, grade, avg_sal from   
  110.     (select deptno, avg(sal) avg_sal from emp group by deptno) t   
  111.     join salgrade on(t.avg_sal between s.losal and s.hisal)   
  112.      )   
  113.    )//求平均薪水等级最低的部门的名称 哈哈 确实比较麻烦   
  114. 78、create view v$_dept_avg_sal_info as   
  115.     select deptno, grade, avg_sal from   
  116.        (select deptno, avg(sal) avg_sal from emp group by deptno) t   
  117.     join salgrade on(t.avg_sal between s.losal and s.hisal);   
  118.     //视图的创建,一般以v$开头,但不是固定的   
  119.   
  120.   
  121.   
  122.   
  123.   
  124. 79、select t1.deptno, grade, avg_sal from v$_dept_avg_sal_info t1   
  125.     join dept on (t1.deptno dept.deptno)   
  126.     where t1.grade    
  127.       (   
  128.         select min(grade) from   
  129.          v$_dept_avg_sal_info t1   
  130.      )   
  131.    )//求平均薪水等级最低的部门的名称 用视图,能简单一些,相当于Java中方法的封装   
  132.   
  133. 80、---创建视图出现权限不足时候的解决办法:   
  134.     conn sys/admin as sysdba;   
  135.         显示:连接成功 Connected   
  136.     grant create table, create view to scott;   
  137.         显示: 授权成功 Grant succeeded   
  138. 81、-------求比普通员工最高薪水还要高的经理人的名称 -------   
  139.     select ename, sal from emp where empno in   
  140.        (select distinct mgr from emp where mgr is not null)   
  141.     and sal >   
  142.     (   
  143.        select max(sal) from emp where empno not in   
  144.          (select distinct mgr from emp where mgr is not null)   
  145.     )   
  146. 82、---面试题:比较效率   
  147.        select from emp where deptno 10 and ename like '%A%';//好,将过滤力度大的放在前面   
  148.        select from emp where ename like '%A% and deptno 10;   
  149. 83、-----表的备份   
  150.        create table dept2 as select from dept;   
  151. 84、-----插入数据   
  152.         insert into dept2 values(50,'game','beijing');   
  153.       ----只对某个字段插入数据   
  154.         insert into dept2(deptno,dname) values(60,'game2');   
  155. 85、-----将一个表中的数据完全插入另一个表中(表结构必须一样)   
  156.     insert into dept2 select from dept;   
  157. 86、-----求前五名员工的编号和名称(使用虚字段rownum 只能使用 或 要使用 必须使用子查询)   
  158.     select empno,ename from emp where rownum <= 5;   
  159. 86、----求10名雇员以后的雇员名称--------   
  160.     select ename from (select rownum r,ename from emp) where 10;   
  161. 87、----求薪水最高的前5个人的薪水和名字---------   
  162.     select ename, sal from (select ename, sal from emp order by sal desc) where rownum <=5    
  163. 88、----求按薪水倒序排列后的第6名到第10名的员工的名字和薪水--------   
  164.     select ename, sal from   
  165.            (select ename, sal, rownum from   
  166.               (select ename, sal from emp order by sal desc)   
  167.            )   
  168.         where r>=6 and r<=10  
  169. 89、----------------创建新用户---------------   
  170.     1、backup scott//备份   
  171.         exp//导出   
  172.     2、create user   
  173.         create user guohailong identified(认证) by guohailong  default tablespace users quota(配额) 10M on users   
  174.         grant create session(给它登录到服务器的权限),create table, create view to guohailong   
  175.     3import data   
  176.         imp   
  177. 90、-----------事务回退语句--------   
  178.     rollback;   
  179.        
  180. 91、-----------事务确认语句--------   
  181.     commit;//此时再执行rollback无效   
  182.   
  183. 92、当正常断开连接的时候例如exit,事务自动提交。  当非正常断开连接,例如直接关闭dos窗口或关机,事务自动提交   
  184. 93、有3个表S,C,SC    
  185.     S(SNO,SNAME)代表(学号,姓名)    
  186.     C(CNO,CNAME,CTEACHER)代表(课号,课名,教师)    
  187.     SC(SNO,CNO,SCGRADE)代表(学号,课号成绩)    
  188.     问题:    
  189.     1,找出没选过“黎明”老师的所有学生姓名。    
  190.     2,列出2门以上(含2门)不及格学生姓名及平均成绩。    
  191.     3,即学过1号课程有学过2号课所有学生的姓名。   
  192.     答案:   
  193.     1、   
  194.         select sname from join sc on(s.sno sc.sno) join on (sc.cno c.cno) where cteacher <> '黎明';   
  195.     2、   
  196.         select sname where sno in (select sno from sc where scgrade 60 group by sno having count(*) >=2);   
  197.     3、   
  198.         select sname from where sno in (select sno, from sc where cno=1 and cno in   
  199.                             (select distinct sno from sc where cno 2);   
  200.                          )   
  201.   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值