Oracle第一节课

1、   查询员工表所有数据, 并说明使用*的缺点

Select * from emp;

缺点是使用“*”的效率不高

2、   查询职位(JOB)为'PRESIDENT'的员工的工资

select sal from empwhere job='PRESIDENT'; 

3、   查询佣金(COMM)为0 或为NULL 的员工信息

select * from empwhere comm is null or comm=0;

4. 查询入职日期在1981-5-1 到1981-12-31 之间的所有员工信息

      select * from emp where hiredate betweento_date('1981-05-01','YYYY-MM-DD') and to_date('1981-12-31','YYYY-MM-DD'); 

05.查询所有名字长度为4的员工的员工编号,姓名

selectempno,ename from emp where length(ename)=4;

06.显示10 号部门的所有经理('MANAGER')和20 号部门的所有职员('CLERK')的详细信息

select* from emp where deptno=10 and job='MANAGER' or deptno=20 and job='CLERK'; 

  1. 07.显示姓名中没有'L'字的员工的详细信息或含有'SM'字的员工信息
  2. select* from emp where ename not like '%L%' or ename like '%SM%';
  3. 08.显示各个部门经理('MANAGER')的工资
  4. selectsal from emp where job='MANAGER'; 
  5. 09.显示佣金(COMM)收入比工资(SAL)高的员工的详细信息
  6. Select* from emp where comm>sal;
  7. 总结:今天学习orcale数据库,在win7系统下安装orcale的时候比较麻烦,需要配置一些文件。在网上都能查到。
  8. 1、   安装成功后进入DOS界面操作
  9. 在进行以下操作时,需启动oracle服务。
  10. A、进入sql界面:开始--运行--cmd:输入sqlplus 回车
  11. 提示输入正确的用户名和密码
  12. B、开始—>所有程序-oracle的-运行sql命令—>直接采用conn 用户名/密码进入
  13.  
  14. 用户名 默认的是 sys,system.
  15. 密码是你安装的密码
  16. 输入正确的用户名及密码即可进入界面。
  17.  
  18. 2、密码修改
  19. 当忘记密码时,可以采用
  20. sqlplussys/aaa as sysdba;--以数据库管理员的身份登录. 如果在本机登录
  21. 密码可以随意输入。
  22.  
  23. 修改密码:
  24. //修改system用户的密码是system
  25. alteruser system identified by system;
  26. alteruser identified by 都是关键字。
  27.  
  28.  
  29. 3、切换用户操作
  30.   A、先退出 再登陆
  31.     exit;退出。
  32.   1、登录命令 sqlplus system/system 直接登录
  33.   2、sqlplus
  34.      --提示输入用户名
  35.      --提示输入密码
  36.  B、也可以不退出直接在sql>操作中采用conn scott/tiger  conn/用户名/密码切换用户
  37. 注意:登录的时候没有分号结束。
  38. 简单入门命令
  39. select* from tabs;---查询当前用户下有哪些表(多查询出系统表);
  40. selecttable_name from user_tables; ---查询当前用户下的所有表的名称。
  41.  
  42. desc表名  ---查看表有哪些列(表的结构)
  43. 创建用户命令
  44.  A、连接到用户SQL> conn system/root
  45. B、创建用户: SQL> createuser scott identified by tiger;
  46. C、切换用户:SQL> connscott/tiger    //用户切换失败
  47. Notlogged on
  48.   备注:出现用户没有session权限的提示.
  49. 所以应当分配session权限
  50. 8、分配权限
  51. grant权限名 to 用户名;
  52. SQL>conn system/root;//第一步切换到管理员
  53. SQL>grant create session to scott; //为用户受权
  54. Grantsucceeded//受权成功
  55. 备注当受权成功后,scott就可以登录,但是登录后,当用户创建表时,也会出现权限不足.然在oracle中是通过用户的角色来给用户分配权限的.详细参考9角色
  56.  
  57. 9、角色(一个角色包含多个权限)
  58. connect
  59.    create session
  60.    create table
  61.    ……
  62.  resource
  63.     对表空间使用权限
  64.     ……
  65.    grant connect,resource to scott;
  66. 注意:对用用户的创建,权限的分配,只有管理员才能够操作,普通用户不能实现.
  67.  
  68.  
  69. 登录简单总结
  70.  SQL Plus 登录的几种不同方式
  71. •  sqlplus 根据提示输入用户名、密码
  72. •  sqlplus 用户名/密码   (本机登录)
  73. •  sqlplus 用户名/密码@网络服务名 (远程登录)
  74. •  sqlplus / as sysdba   (以sysdba身份登录,用户实际为sys)
  75.  
  76.  
  77. 总结:
  78. 创建用户
  79.     切换到system管理员中 以system管理员进行登录
  80.    
  81.     1、Create user 用户名identified by 密码;(不能是全数字)
  82.     2、grant create session,create table,resource to用户名;//给用户分配权限
  83.     3、start  目录(D:\emp.sql);//注意该文件不能放在桌面 为什么呢(目录中不能包含空格否则会出现如下错误:
  84. SQL>start C:\a a a\emp.sql;
  85. Errorreading file
  86. )
  87. SQLPlus常见的命令
  88.  conn    切换连接用户
  89.  desc    显示表结构
  90.  host    执行操作系统命令
  91.  start   执行文件系统SQL语句
  92.  exit       退出
  93.  col        格式化输出
  94.  /       执行最近一条SQL或新定义过程
  95.  startup    启动数据库实例 (DBA)
  96.  shutdown   关闭数据库实例 (DBA)
  97. 对于conn,desc,host,exit已经结束
  98.  
  99. 首先创建scott用户
  100. 为用户分配角色
  101.  
  102. 采用start命令 导入并执行数据库库脚本文件
  103. SQL>start c:/emp.sql
  104.  
  105. / :执行最近一条SQL 例如:
  106. SQL>select * from dual;
  107. DUMMY
  108. -----
  109. X
  110. SQL>/  当使用/会执行上面一条语句相同的命令操作
  111. DUMMY
  112. -----
  113. X
  114.  
  115. SQL>
  116. startupshutdown必须是sys system用户才能够执行
  117. 其它用户不能使用.并且此命令只能在sqlplus中执行.不能在客户端工具中使用。
  118.  
  119.  
  120.  
  121.  

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值