`
liufei.fir
  • 浏览: 685117 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

oracle之pl/sql

阅读更多
四、ORACLE用户连接的管理

            用系统管理员,查看当前数据库有几个用户连接:

            SQL> select username,sid,serial# from v$session;

            如果要停某个连接用

            SQL> alter system kill session 'sid,serial#';

            如果这命令不行,找它UNIX的进程数

            SQL> select pro.spid from v$session ses,v$process pro where
            ses.sid=21 and ses.paddr=pro.addr;

            说明:21是某个连接的sid数

            然后用 kill 命令杀此进程号。


            五、SQL*PLUS使用
            a、进入SQL*Plus
            $sqlplus 用户名/密码

               退出SQL*Plus
            SQL>exit

            b、在sqlplus下得到帮助信息
            列出全部SQL命令和SQL*Plus命令
            SQL>help
            列出某个特定的命令的信息
            SQL>help 命令名

            c、显示表结构命令DESCRIBE
            SQL>DESC 表名

            d、SQL*Plus中的编辑命令
            显示SQL缓冲区命令
            SQL>L

            修改SQL命令
            首先要将待改正行变为当前行
            SQL>n
            用CHANGE命令修改内容
            SQL>c/旧/新
            重新确认是否已正确
            SQL>L

            使用INPUT命令可以在SQL缓冲区中增加一行或多行
            SQL>i
            SQL>输入内容

            e、调用外部系统编辑器
            SQL>edit 文件名
            可以使用DEFINE命令设置系统变量EDITOR来改变文本编辑器的类型,在login.sql文件中定义如下一行
            DEFINE_EDITOR=vi

            f、运行命令文件
            SQL>START test
            SQL>@test

            常用SQL*Plus语句
            a、表的创建、修改、删除
            创建表的命令格式如下:
            create table 表名 (列说明列表);

            为基表增加新列命令如下:
            Alter TABLE 表名 ADD (列说明列表)
            例:为test表增加一列Age,用来存放年龄
                sql>alter table test
                    add (Age number(3));

            修改基表列定义命令如下:
            Alter TABLE 表名
            MODIFY (列名 数据类型)
            例:将test表中的Count列宽度加长为10个字符
                sql>alter atble test
                    modify (County char(10));

            b、将一张表删除语句的格式如下:
            DORP TABLE 表名;
            例:表删除将同时删除表的数据和表的定义
            sql>drop table test

            c、表空间的创建、删除


            六、ORACLE逻辑备份的SH文件

            完全备份的SH文件:exp_comp.sh

            rq=` date +%m%d `

            su - oracle -c exp system/manager full=y inctype=complete
            file=/oracle/export/db_comp$rq.dmp

            累计备份的SH文件:exp_cumu.sh

            rq=` date +%m%d `

            su - oracle -c exp system/manager full=y inctype=cumulative
            file=/oracle/export/db_cumu$rq.dmp

            增量备份的SH文件: exp_incr.sh

            rq=` date +%m%d `

            su - oracle -c exp system/manager full=y inctype=incremental
            file=/oracle/export/db_incr$rq.dmp

            root用户crontab文件
            /var/spool/cron/crontabs/root增加以下内容

            0 2 1 * * /oracle/exp_comp.sh

            30 2 * * 0-5 /oracle/exp_incr.sh

            45 2 * * 6 /oracle/exp_cumu.sh

            当然这个时间表可以根据不同的需求来改变的,这只是一个例子。

            七、ORACLE 常用的SQL语法和数据对象

            一.数据控制语句 (DML) 部分

            1.Insert (往数据表里插入记录的语句)

            Insert INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……);
            Insert INTO 表名(字段名1, 字段名2, ……) Select (字段名1, 字段名2, ……) FROM 另外的表名;

            字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’
            如果字段值里包含单引号’ 需要进行字符串转换, 我们把它替换成两个单引号''.
            字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验.

            日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒
            或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
            TO_DATE()还有很多种日期格式, 可以参看ORACLE DOC.
            年-月-日 小时:分钟:秒 的格式YYYY-MM-DD HH24:MI:SS

            Insert时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,
            方法借用ORACLE里自带的DBMS_LOB程序包.

            Insert时如果要用到从1开始自动增长的序列号, 应该先建立一个序列号
            Create SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY 1 START WITH 1
            MAXVALUE 99999 CYCLE NOCACHE;
            其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999
            Insert 语句插入这个字段值为: 序列号的名称.NEXTVAL

            2.Delete (删除数据表里记录的语句)

            Delete FROM表名 Where 条件;

            注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused.

            如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间
            TRUNCATE TABLE 表名;
            此操作不可回退.

            3.Update (修改数据表里记录的语句)

            Update表名 SET 字段名1=值1, 字段名2=值2, …… Where 条件;

            如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验;
            值N超过定义的长度会出错, 最好在插入前进行长度校验..

            注意事项:
            A. 以上SQL语句对表都加上了行级锁,
                    确认完成后, 必须加上事物处理结束的命令 COMMIT 才能正式生效,
                    否则改变不一定写入数据库里.
                    如果想撤回这些操作, 可以用命令 ROLLBACK 复原.

            B. 在运行Insert, Delete 和 Update 语句前最好估算一下可能操作的记录范围,
                    应该把它限定在较小 (一万条记录) 范围内,. 否则ORACLE处理这个事物用到很大的回退段.
                    程序响应慢甚至失去响应. 如果记录数上十万以上这些操作, 可以把这些SQL语句分段分次完成,
                    其间加上COMMIT 确认事物处理.


            二.数据定义 (DDL) 部分

            1.Create (创建表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等)

            orACLE常用的字段类型有
            CHAR                        固定长度的字符串
            VARCHAR2                可变长度的字符串
            NUMBER(M,N)                数字型M是位数总长度, N是小数的长度
            DATE                        日期类型

            创建表时要把较小的不为空的字段放在前面, 可能为空的字段放在后面

            创建表时可以用中文的字段名, 但最好还是用英文的字段名

            创建表时可以给字段加上默认值, 例如 DEFAULT SYSDATE
            这样每次插入和修改时, 不用程序操作这个字段都能得到动作的时间

            创建表时可以给字段加上约束条件
            例如 不允许重复 UNIQUE, 关键字 PRIMARY KEY

            2.Alter (改变表, 索引, 视图等)

            改变表的名称
            Alter TABLE 表名1 TO 表名2;

            在表的后面增加一个字段
            Alter TABLE表名 ADD 字段名 字段名描述;

            修改表里字段的定义描述
            Alter TABLE表名 MODIFY字段名 字段名描述;

            给表里的字段加上约束条件
            Alter TABLE 表名 ADD CONSTRAINT 约束名 PRIMARY KEY (字段名);
            Alter TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE (字段名);

            把表放在或取出数据库的内存区
            Alter TABLE 表名 CACHE;
            Alter TABLE 表名 NOCACHE;

            3.Drop        (删除表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等)

            删除表和它所有的约束条件
            Drop TABLE 表名 CASCADE CONSTRAINTS;

            4.TRUNCATE (清空表里的所有记录, 保留表的结构)

            TRUNCATE 表名;

            三.查询语句 (Select) 部分

            Select字段名1, 字段名2, …… FROM 表名1, [表名2, ……] Where 条件;

            字段名可以带入函数
              例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名),
                       TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')

            NVL(EXPR1, EXPR2)函数
            解释:
            IF EXPR1=NULL
                            RETURN EXPR2
            ELSE
                                   RETURN EXPR1

            DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函数
            解释:
            IF AA=V1 THEN RETURN R1
            IF AA=V2 THEN RETURN R2
            ..…
            ELSE
            RETURN NULL

            LPAD(char1,n,char2)函数
            解释:
            字符char1按制定的位数n显示,不足的位数用char2字符串替换左边的空位

            字段名之间可以进行算术运算
            例如: (字段名1*字段名1)/3

            查询语句可以嵌套
            例如: Select …… FROM
            (Select …… FROM表名1, [表名2, ……] Where 条件) Where 条件2;

            两个查询语句的结果可以做集合操作
            例如: 并集UNION(去掉重复记录), 并集UNION ALL(不去掉重复记录), 差集MINUS, 交集INTERSECT

            分组查询
            Select字段名1, 字段名2, …… FROM 表名1, [表名2, ……] GROUP BY字段名1
            [HAVING 条件] ;

            两个以上表之间的连接查询

            Select字段名1, 字段名2, …… FROM 表名1, [表名2, ……] Where
                            表名1.字段名 = 表名2. 字段名 [ AND ……] ;

            Select字段名1, 字段名2, …… FROM 表名1, [表名2, ……] Where
                            表名1.字段名 = 表名2. 字段名(+) [ AND ……] ;

            有(+)号的字段位置自动补空值

            查询结果集的排序操作, 默认的排序是升序ASC, 降序是DESC

            Select字段名1, 字段名2, …… FROM 表名1, [表名2, ……]
            orDER BY字段名1, 字段名2 DESC;

            字符串模糊比较的方法

            INSTR(字段名, ‘字符串’)>0
            字段名 LIKE ‘字符串%’ [‘%字符串%’]

            每个表都有一个隐含的字段ROWID, 它标记着记录的唯一性.

            四.ORACLE里常用的数据对象 (SCHEMA)

            1.索引 (INDEX)

            Create INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
            Alter INDEX 索引名 REBUILD;

            一个表的索引最好不要超过三个 (特殊的大表除外), 最好用单字段索引, 结合SQL语句的分析执行情况,
            也可以建立多字段的组合索引和基于函数的索引

            orACLE8.1.7字符串可以索引的最大长度为1578 单字节
            orACLE8.0.6字符串可以索引的最大长度为758 单字节

            2.视图 (VIEW)

            Create VIEW 视图名AS Select …. FROM …..;
            Alter VIEW视图名 COMPILE;

            视图仅是一个SQL查询语句, 它可以把表之间复杂的关系简洁化.

            3.同义词 (SYNONMY)
            Create SYNONYM同义词名FOR 表名;
            Create SYNONYM同义词名FOR 表名@数据库链接名;

            4.数据库链接 (DATABASE LINK)
            Create DATABASE LINK数据库链接名CONNECT TO 用户名 IDENTIFIED BY 密码 USING
            ‘数据库连接字符串’;

            数据库连接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定义.

            数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样

            数据库全局名称可以用以下命令查出
            Select * FROM GLOBAL_NAME;

            查询远端数据库里的表
            Select …… FROM 表名@数据库链接名;

            五.权限管理 (DCL) 语句

            1.GRANT        赋于权限
            常用的系统权限集合有以下三个:
            CONNECT(基本的连接), RESOURCE(程序开发), DBA(数据库管理)
            常用的数据对象权限有以下五个:
            ALL         ON 数据对象名,         Select ON 数据对象名,         Update ON
            数据对象名,
            Delete         ON 数据对象名, Insert ON 数据对象名,   Alter ON 数据对象名

            GRANT CONNECT, RESOURCE TO 用户名;
            GRANT Select ON 表名 TO 用户名;
            GRANT Select, Insert, Delete ON表名 TO 用户名1, 用户名2;

            2.REVOKE 回收权限

            REVOKE CONNECT, RESOURCE FROM 用户名;
            REVOKE Select ON 表名 FROM 用户名;
            REVOKE Select, Insert, Delete ON表名 FROM 用户名1, 用户名2;
分享到:
评论

相关推荐

    oracle 9i pl/sql程序设计笔记

    ### Oracle 9i PL/SQL程序设计笔记精要 #### PL/SQL基础知识概览 **标题与描述**:本文档围绕“Oracle 9i PL/SQL程序设计笔记”这一核心主题,深入探讨了PL/SQL语言的基础知识及其在Oracle 9i数据库环境中的应用。...

    oracle10g_pl/sql

    Oracle 10g PL/SQL 是Oracle数据库系统中用于创建和管理存储过程、函数、触发器等数据库对象的编程语言。本教程旨在为初学者提供一个全面的学习平台,同时也为经验丰富的开发者提供参考资料。PL/SQL是Oracle特有的...

    Oracle PL/SQL实战(待续)

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据处理能力与PL的程序设计特性,是Oracle数据库系统中用于创建存储过程、函数、触发器和包的主要工具。在这个"Oracle PL/SQL实战(待续)"的主题中,我们将深入...

    oracle pl/sql从入门到精通 配套源代码

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL(结构化查询语言)的数据库操作功能与PL/SQL的程序设计特性,广泛应用于Oracle数据库的开发和管理。这本书"Oracle PL/SQL从入门到精通"的配套源代码,显然是为了...

    Oracle PL/SQL程序设计(第5版)(套装上下册)

    《Oracle PL/SQL程序设计(第5版)(套装上下册)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何...

    ORACLE PL/SQL从入门到精通

    ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括触发器、过程、函数、软件包、异常处理、游标、循环、分支、变量使用、数据库安装等关键知识点。 触发器是数据库中用来保证数据...

    Oracle PL/SQL实例精解 数据库建立代码

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据库操作能力和PL/SQL的结构化编程特性,使得数据库开发者能够创建复杂的应用程序和数据库逻辑。在"Oracle PL/SQL实例精解 数据库建立代码"中,我们将深入探讨...

    Oracle PL/SQL程序设计(第5版)(上下册)

    ### Oracle PL/SQL程序设计(第5版)(上下册)知识点概述 #### 一、PL/SQL编程基础 - **PL/SQL简介**:PL/SQL(Procedural Language for SQL)是Oracle数据库的一种内嵌式过程化语言,用于增强SQL的功能。它允许在SQL...

    Oracle8 PL/SQL程序设计

    Oracle 8 PL/SQL程序设计是一门深度探讨Oracle数据库中PL/SQL编程语言的应用技术的主题。PL/SQL,全称Procedural Language/Structured Query Language,是Oracle数据库提供的一种过程化编程语言,它结合了SQL的查询...

    PL/SQL Developer 远程连接Oracle数据库

    PL/SQL Developer是一款专为Oracle数据库设计的集成开发环境,它极大地简化了PL/SQL语言的编写、调试和管理任务。远程连接Oracle数据库是PL/SQL Developer的一项关键功能,允许用户在本地计算机上操作和管理远程...

    Oracle 12c PL/SQL程序设计终极指南

    本书以Oracle的最新版本12c为基础,呈现的是最新的PL/SQL技术,这一点也优于已出版的同类书.全书以一个综合性的人力资源项目为驱动,不仅能将各个理论知识点很好地融入实践,而且还能让读者体验完整的项目实操过程...

    Oracle PL/SQL 实例精解(第4版涵盖Oracle 11g)+源码脚本

    Oracle PL/SQL是一种强大的编程语言,它将关系数据库的强大功能与结构化编程的优点结合在一起,是Oracle数据库系统中不可或缺的一部分。在"Oracle PL/SQL 实例精解(第4版涵盖Oracle 11g)+源码脚本"中,读者可以深入...

    Oracle Database 12c PL/SQL开发指南 实例源代码

    PL/SQL是Oracle专为数据库管理设计的一种过程化编程语言,它结合了SQL查询语言的威力与高级编程语言的灵活性,使得数据库开发者能够创建复杂的应用程序逻辑。 在"Oracle Database 12c PL/SQL开发指南(第7版)"这...

    oracle 中 pl/sql 只是学习方法

    Oracle中的PL/SQL是一种强大的编程语言,它是Oracle数据库与应用程序之间的桥梁,专为数据库操作而设计。PL代表“过程化语言”(Procedural Language),SQL则是“结构化查询语言”(Structured Query Language)。...

    Oracle PL/SQL学习官方教材

    Oracle PL/SQL是一种强大的编程语言,它将SQL与过程编程语言的特性相结合,为数据库开发提供了丰富的功能。在Oracle数据库环境中,PL/SQL是开发高效、可靠和可维护的数据库应用程序的关键工具。以下是对"Oracle PL/...

    Oracle PL/SQL专家指南-高级PL/SQL解决方案的设计与开发

    《Oracle PL/SQL专家指南-高级PL/SQL解决方案的设计与开发》是一本深入探讨Oracle数据库中的PL/SQL编程的专业书籍。PL/SQL是Oracle数据库特有的编程语言,它结合了SQL的查询能力与过程式编程语言的功能,使得数据库...

    oracle_oracle_oraclepl/sql_

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL(结构化查询语言)的数据库操作能力和过程性编程语言的控制结构。在"Oracle PL/SQL"这本书中,作者深入浅出地探讨了这一语言的核心概念和实用技巧,尤其适合法语...

    oracle pl/sql实例精讲student数据库模式数据和表脚本

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据库操作能力和Procedural Language的编程结构,用于在Oracle数据库环境中创建复杂的应用程序。在"Oracle PL/SQL实例精讲student数据库模式"中,我们将深入探讨...

    精通Oracle_PL/SQL

    精通Oracle PL/SQL》旨在教授读者写出健壮、高效且易于维护的 PL/SQL代码。全书涵盖了 PL/SQL提供的大量功能,包括高效数据处理、安全、触发器、DBA包以及高效的调试技术等。此外,书中含有丰富的示例,并提供了大量...

Global site tag (gtag.js) - Google Analytics