首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 虚拟主机评测对比
sql*plus使用的一些技巧-数据库专栏,SQL Server
作者:网友供稿 点击:16
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

sql*plus使用的一些技巧sql*plus中蕴藏着好多技巧,如果掌握这些技巧,对于在oracle数据库下进行快速开发与有效维护数据库都是有益的。        下面就接受一二,        1.使用sql*plus动态生成批量脚本将spool与select命令结合起来使用,可以生成一个脚本,脚本中包含有可以批量执行某一任务的语句。例1:生成一个脚本,删除scott用户下的所有的表:a. 创建gen_drop_table.sql文件,包含如下语句:spool  c:\drop_table.sql      select drop table || table_name ||; from user_tables;      spool off b. 以scott用户登录数据库sqlplus > @ …..\gen_dorp_table.sqlc. 在c盘根目录下会生成文件drop_table.sql文件,包含删除所有表的语句,如下所示:sql>      select drop table || table_name ||; from user_tables;                                                                                               droptable||table_name||;                           -------------------------------------------------------------------------------- drop table dept;                                         drop table emp;                                         drop table parent;                                      drop table stat_vender_temp;                      drop table table_forum;                                                                                                               5 rows selected.                               sql>      spool off  d. 对生成的drop_table.sql文件进行编辑去掉不必要的部分,只留下drop table …..语句e. 在scott用户下运行dorp_table.sql文件,删除scott用户下所有的表。sqlplus > @ c:\dorp_table.sql在上面的操作中,在生成的脚本文件中会有多余的字符,如运行的sql语句,标题,或返回的行数,需要我们编辑该脚本后再运行,给实际的操作带来诸多不便。懒惰是人的本性,这促使我们用更简单的办法来实现上面的任务。a. 创建gen_drop_table.sql文件,包含如下语句:        set echo offset feedback offset newpage noneset pagesize 5000set linesize 500set verify offset pagesize 0set term offset trims onset linesize 600set heading  off set timing offset verify offset numwidth 38spool  c:\drop_table.sql      select drop table || table_name ||; from user_tables;      spool off b. 以scott用户登录数据库sqlplus > @ …..\gen_dorp_table.sqlc. 在c盘根目录下会生成文件drop_table.sql文件,包含删除所有表的语句,如下所示:drop table dept;                                         drop table emp;                                         drop table parent;                                      drop table stat_vender_temp;                      drop table table_forum;                              d. 在scott用户下运行dorp_table.sql文件,删除scott用户下所有的表。sqlplus > @ c:\dorp_table.sql2.将一个表中的数据导出生成一个文本文件,列与列之间以”,”隔开set echo offset feedback offset newpage noneset pagesize 5000set linesize 500set verify offset pagesize 0set term offset trims onset linesize 600set heading  off set timing offset verify offset numwidth 38spool  c:\drop_table.sql      select deptno || , || dname from dept;     spool off 将上面的内容保存为一个文本文件后,以scott登录,执行该文件后显示结果:10,accounting  20,research  30,sales  40,operations  通过上面的两个例子,我们可以将:set echo offset feedback offset newpage noneset pagesize 5000set linesize 500set verify offset pagesize 0set term offset trims onset linesize 600set heading  off set timing offset verify offset numwidth 38spool  c:\具体的文件名      你要运行的sql语句     spool off作为一个模版,只要将必要的语句假如这个模版就可以了。在oracle的较新版本中,还可以用set colsep命令来实现上面的功能:sql> set colsep ,sql> select * from dept;        10,accounting    ,new york        20,research      ,dallas        30,sales         ,chicago        40,operations    ,boston        35,aa            ,bb3.动态生成spool命令所需的文件名在我们上面的例子中,spool命令所需要的文件名都是固定的。有时我们需要每天spool一次,并且每次spool的文件名都不相同,如文件名包含当天的日期,该如何实现呢?column dat1 new_value filename;select to_char(sysdate,yyyymmddhh24mi) dat1 from dual;  spool c:\&&filename..txt  select * from dept;spool off;4.如何从脚本文件中得到windows环境变量的值:在windos中:spool c:\temp\%oracle_sid%.txt   select * from dept;   ...   spool off在上面的例子中,通过%oracle_sid%的方式引用环境变量oracle_sid的值,如果oracle_sid的值为orcl,则生成的spool文件名为:orcl.txt在unix中:spool c:\temp\$oracle_sid.txt   select * from dept;   ...   spool off在上面的例子中,通过$oracle_sid的方式引用环境变量oracle_sid的值,如果oracle_sid的值为orcl,则生成的spool文件名为:orcl.txt5.如何指定缺省的编辑脚本的目录        在sql*plus中,可以用save命令,将上一条执行的sql语句保存到一个文件中,但是如何设置该文件的缺省目录呢?通过sql> set editfile c:\temp\file.sql 命令,可以设置其缺省目录为c:\tmpe,缺省文件名为file.sql。6.如何除去表中相同的行找到相同的行:select * from dept a   where rowid <> (select max(rowid)                   from dept b                   where a.deptno = b.deptno                   and a.dname = b.dname  -- make sure all columns are compared                   and a.loc = b.loc);注释:如果只找deptno列相同的行,上面的查询可以改为:select * from dept a   where rowid <> (select max(rowid)                   from dept b                   where a.deptno = b.deptno)删除相同的行:delete from dept awhere rowid <> (select max(rowid                                from dept b                                where a.deptno = b.deptno                                and a.dname = b.dname -- make sure all columns are compared                                and a.loc = b.loc);注意:上面并不删除列值为null的行。7.如何向数据库中插入两个单引号(’’)insert inot dept values(35,’aa’’’’bb’,’a’’b’);在插入时,用两个’表示一个’。8.如何设置sql*plus的搜寻路径,这样在用@命令时,就不用输入文件的全路径。设置sqlpath环境变量。如:sqlpath = c:\orant\dbs;c:\apps cripts;c:\myscripts9.@与@@的区别是什么?@等于start命令,用来运行一个sql脚本文件。@命令调用当前目录下的,或指定全路径,或可以通过sqlpath环境变量搜寻到的脚本文件。@@用在脚本文件中,用来指定用@@执行的文件与@@所在的文件在同一目录,而不用指定全路径,也不从sqlpath环境变量指定的路径中寻找文件,该命令一般用在嵌套脚本文件中。10.&与&&的区别&用来创建一个临时变量,每当遇到这个临时变量时,都会提示你输入一个值。&&用来创建一个持久变量,就像用用define命令或带new_vlaue字句的column命令创建的持久变量一样。当用&&命令引用这个变量时,不会每次遇到该变量就提示用户键入值,而只是在第一次遇到时提示一次。如,将下面三行语句存为一个脚本文件,运行该脚本文件,会提示三次,让输入deptnoval的值:select count(*) from emp where deptno = &deptnoval;select count(*) from emp where deptno = &deptnoval;select count(*) from emp where deptno = &deptnoval;将下面三行语句存为一个脚本文件,运行该脚本文件,则只会提示一次,让输入deptnoval的值:select count(*) from emp where deptno = &deptnoval;select count(*) from emp where deptno = &deptnoval;select count(*) from emp where deptno = &deptnoval;11.引入copy的目的copy命令在两个数据库之间拷贝数据时特别有用,特别是该命令可以在两个数据库之间传递long型字段的数据。缺点:在两个数据库之间传递数据时,有可能丢失精度(lose precision)。12.问什么在修改大量的行时,我的脚本会变得很慢?当通过pl/sql块修改一个表中的许多行时,你会创建在表上创建一个cursor,但是只有在你关闭cursor时,才会释放rollback segment,这样,当cursor仍然打开时,修改过程会变慢,这是因为数据库不得不搜寻大量的rollback segment以便于维护读一致性。为了避免这样情况,试着在表上加一个标志字段来描述该行是否已经被修改,然后关闭该cursor,然后再打开该cursor。每次可以修改5000行.

转此:http://www.cnoug.org/viewthread.php?tid=31451

文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·Asp.Net下导出/导入规则的Excel(.xls)文件-ASP教程,ASP应用
·中国万网,万网
·中资源
·上海火速
·加拿大中文网
·华夏名网
·世纪东方
·商务中国
·中国E动网
·神话网络
最新文章
·photoshop抠图合成特效:飞出照片相框_photoshop教程
·将升级的windows vista驱动还原到原来的版本_windows vista
·photoshop漫画笔刷绘制非主流照片漫画_photoshop教程
·看域名注册信息判断网赚公司真假_网赚技巧
·找坐标:对网站进行坐标定位_站长心得
·如何增加网站pv_站长心得
·google性格一:对活跃度高的网页收录很快_google推广
·googleadsense容易被k的可能性列表_google推广
·价值数万的googlepr作弊方_google推广
·如何抢占人家的“首要意念”_google推广
相关主题
  • SQL*PLUS命令的使用大全-数据库专栏,SQL Server
  • SQL*PLUS命令的使用大全-数据库专栏,SQL Server
  • SQL*PLUS 初学-数据库专栏,SQL Server
  • SQL*PLUS常用命令:-数据库专栏,SQL Server
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭