oracle概述与总结1

    技术2022-05-20  40

    Oracle基础与总结

    一,基本概念:

    oracle数据库是一种大型数据库系统,一般应用于商业,政府部门,它的功能很强大,能够处理大批量的数据,在网络方面也用的非常多。不过,一般的中小型企业都比较喜欢用mysql, SQL server等数据库系统,它的操作很简单,功能也非常齐全。只是比较oracle数据库而言,在处理大量数据方面有些不如。

    特点:

    支持多用户、大事务量的事务处理

    数据安全性和完整性的有效控制

    支持分布式数据处理

    优点:

    1.Oracle的稳定性要比Sql server好。

    2.Oracle在导数据工具sqlload.exe功能比SqlserverBcp功能强大,Oracle可以按照条件把文本文件数据导入.

    3.Oracle的安全机制比Sql server好。

    4.Sql server的易用性和友好性方面要比Oracle好。

    5.在处理大数据方面Oracle会更稳定一些。

    6.Sql Server在数据导出方面功能更强一些。

    7.处理速度方面比Sql server快一些,和两者的协议有关.

    二,基本操作

    1、  安装成功后进入DOS界面操作

    在进行以下操作时,需启动oracle服务。

    A、进入sql界面:开始--运行--cmd:输入sqlplus 回车

    提示输入正确的用户名和密码

    B、开始—>所有程序-àoracle-à运行sql命令—>直接采用conn 用户名/密码 进入

     

    用户名 默认的是 sys,system.

    密码是你安装的密码

    输入正确的用户名及密码即可进入界面。

     

    2、密码修改

    当忘记密码时,可以采用

    sqlplus sys/aaa as sysdba;--以数据库管理员的身份登录. 如果在本机登录

    密码可以随意输入。

     

    修改密码:

    //修改system用户的密码是system

    alter user system identified by system;

    alter user identified by 都是关键字。

     

     

    3、切换用户操作

      A、先退出 再登陆

    exit;退出。

    三,相关操作

      1、登录命令 sqlplus system/system 直接登录

      2sqlplus

         --提示输入用户名

         --提示输入密码

     B、也可以不退出直接在sql>操作中采用 conn scott/tiger  conn/用户名/密码切换用户

    注意:登录的时候没有分号结束。

     

     

     

    4oracle 中的表是按照用户进行分类的。

       sys 超级用户(权限最高)

       system 数据库管理员(执行大部分管理操作)

      

       自定用户 测试用户

    5--sqlplus远程连接命令

         sqlplus 服务器端的用户名/密码@全局数据库名称

         sqlplus 服务器端的用户名/密码@teacher;即可。

     

    6、创建用户命令

     A、连接到用户SQL> conn system/root

    B、创建用户: SQL> create user scott identified by tiger;

    C、切换用户:SQL> conn scott/tiger    //用户切换失败

    Not logged on

      备注出现用户没有session权限的提示.

    所以应当分配session权限

    7、分配权限

    grant 权限名 to 用户名;

    SQL> conn system/root;//第一步切换到管理员

    SQL> grant create session to scott; //为用户受权

    Grant succeeded//受权成功

    备注当受权成功后,scott就可以登录,但是登录后,当用户创建表时,也会出现权限不足.然在oracle中是通过用户的角色来给用户分配权限的.详细参考9角色

     

    8、角色(一个角色包含多个权限)

    connect

       create session

       create table

       ……

     resource

        对表空间使用权限

        ……

       grant connect,resource to scott;

    四,基本操作案例

    SQL> conn system/red; //切换到system用户

    Connected to Oracle Database 10g Express Edition Release 10.2.0.1.0

    Connected as system

    SQL> create user redarmychen identified by redarmy; //创建用户并为用户设置密码为redarmy

    User created

    SQL>  grant connect,resource to redarmychen; //给用户授权 connect,resource

    Grant succeeded

    SQL> conn redarmychen/redarmy; //切换到新创建的用户中来

    Connected to Oracle Database 10g Express Edition Release 10.2.0.1.0

    Connected as redarmychen

    SQL> start c:/emp.sql;  //导入外部sql文件的方式

    SQL> select * from tabs; //查询该用户下面的所有表

    SQL> select table_name from user_tables; //查询该用户下的所有的表的名称

    五,基本SQL语句

    SQL> select * from emp;//查询所有的字段信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp;//查询所有

    SQL> select empno from emp;//查询部分字段

    SQL> select empno "员工编号" from emp;//采用别名查询

    SQL> select empno as "员工编号" from emp;//采用别名查询 等效于上面的效果

    SQL> select distinct(hiredate) from emp;//查询所有员工的入职日期并且去掉重复的日期

    SQL> select sal+comm from emp;//注意:包含空值的数学表达式求出的结果为空值

    SQL> select empno||ename from emp;//||连接符 把empnoename作为一个字段显示

    SQL> select empno||ename  as "员工编号和员工姓名" from emp;//效果同上

    SQL> select '员工的编号是'||empno from emp;//字符的链接

    SQL> select '姓名为'||ename||'员工,所在的部门是:'||deptno as "新列" from emp;//字段的链接包号字符连接

    SQL> select distinct(deptno) from emp;//查询去掉重复行的员工部门编号

    六,操作相关语句

    //查询部门号为10的员工信息  部门为整数类型

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno=10;

    //查询职位号为MANAGER的员工信息  岗位的类型为字符类型

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER';

    //查询部门号为10并且员工的职位为MANAGER的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where job='MANAGER' and deptno=10;

    //查询部门号大于10的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno>10;

    //查询薪水大于等于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=3000;

    //查询薪水不等于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal<>3000;

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal !=3000;

    //查询薪水大于2000并且小于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>2000 and sal<3000;

    //查询薪水大于等于2000并且小于等于3000的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal between 1600 and 3000;

    //等效于

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where sal>=1600 and sal<=3000;

    //查询部门号位1020的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno in(10,20);

    //注意:相当于如下操作:

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where deptno =10 or deptno=20;

    //查询员工名称以S开头的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like 'S%';

    //查询员工名称以S结尾的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%S';

    //查询员工名称第三个字符为N的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '__N%';

    //查询员工名称中含有N的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%N%';

    //查询员工名称中倒数第二个字符为%的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%_'escape'/';

    //查询员工名称总含有%的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where ename like '%/%%'escape'/';

    //查询奖金为null的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is null;

    //查询奖金非null的员工信息

    SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp where comm is not null;

    七,相关资料

    Condition(s)要使用到比较运算符常用的比较运算符如下:

    操作符

    含义

    =

    等于

    大于

    >=

    大于等于

    小于

    <=

    小于等于

    <> 

    不等于 等效于!=

    其它操作

    And 逻辑运算  逻辑与

    Or  逻辑运算  逻辑或

    Not 逻辑运算  逻辑否

    Between 起始值 and 结束值:使用 BETWEEN 运算来显示在一个区间内的值 包含(起始结束值)

    In: 使用 IN运算显示列表中的值。 In(,,,)相当于一个集合,只要出现集合中匹配的就显示

    Like

    l       使用 LIKE 运算选择类似的值

    l       选择条件可以包含字符或数字:

              % 代表零个或多个字符(任意个字符)

              _ 代表一个字符。

     

    Escape

       回避特殊符号的:使用转义符。例如:将[%]转为[/%][_]转为[/_],然后再加上[ESCAPE ‘/’] 即可

    Null:

    使用 IS (NOT) NULL 判断空值。

    优先级表格:

    优先级

     

    1

    算术运算

    2

    连接符

    3

    比较符

    4

    Is not null like not in

    5

    Not between

    6

    not

    7

    and

    8

    Or

    备注:可以采用括号改变优先级

     

     

       关系数据库-à层次关系---》网状的关系-à关系数据库-à对象关系。

    基础acle


    最新回复(0)