考试网 >> IT认证 >> Oracle >> Oracle指导 >> Oracle数据库常见问题答疑

Oracle数据库常见问题答疑

发布时间:2006-06-28 10:07     点击:
分页:上一页  1 2 3 4 [5] 6 7 8  下一页

SVRMGR> alter user sys identified by

change_on_install;

Statement processed.(已成功更改)

SVRMGR≫ connect sys/change_on_install@ora81

as sysdba;

Connected.(已连接)

你还可以用change_on_install,因为改变SYS用户口令将同时改变口令文件中的口令。当你建立了口令文件后,Oracle数据库在其中放入两个账号:SYS和INTERNAL,并将你在命令行中提供的口令作为这两个账户的口令。当你改变数据库中的SYS用户口令时,数据库将冲掉口令文件中的SYS和INTERNAL口令。下面操作将显示口令foobar已经是无效的了:

学生大博客站 SVRMGR> connect sys/foobar@ora81 as sysdba;

ORA-01017: invalid username/password; logon

denied(无效的用户名/口令,登录被拒绝)

问:利用QUERY选项输出数据

我知道在Oracle8i中,可以使用QUERY有选择地输出表数据。我想用EXP命令来实现,但没有成功。下面是我所写的命令,以及得到的错误信息:

exp ddd/ddd file=/dbf/u11/customer.dmp

tables=AASC.AST_CUSTOMER_KEEP

query=\'where CUA_TRANS_DTS \<

add_months\(sysdate, -6\)\'

table_export[2]: CUA_TRANS_DTS: not found.(没有找到)

答:操作系统不同,用来指定QUERY=参数的方法也不同。WHERE 语句里面往往有很多特殊的字符,如=.>.<和空格等等。而UNIX和Windows操作系统中的外壳命令提示是不欢迎这些字符的,这些字符将被忽略。你应该根据不同的操作系统采用不用的方法。我一般使用带有QUERY选项的参数文件(PARFILE),利用PARFILE,可以不考虑操作系统平台而使用完全相同的方法。

下面给出一个例子。我用select * from all_objects建立了一个表T,我希望输出所有object_id 小于5000的行。在Windows中,必须这样做:

C:\exp>exp userid=tkyte/tkyte tables=t

query="""where object_id < 5000"""

注意:在windows中,需要在WHERE语句的两端使用三个双引号。在UNIX中,必须这样做:
分页:上一页  1 2 3 4 [5] 6 7 8  下一页
版权申明:未经书面授权请勿转载本站信息!!作品版权归所属媒体与作者所有!!
发表评论: 匿名发表 用户名: 查看评论
您将承担一切因您的行为、言论而直接或间接导致的民事或刑事法律责任
留言板管理人员有权保留或删除其管辖留言中的任意内容
本站提醒:不要进行人身攻击。谢谢配合。
在本站搜索相关信息
2003-2005 Ksw123.com All Rights Reserved. - TOP
Copyright © 2006 Ksw123.com. All rights reserved.中国考题网 版权所有