时间:2021-07-01 10:21:17 帮助过:22人阅读
cmd
sqlplus [用户名]/[密码][@数据库] [参数]
sqlplus sys/orcl as sysdba -- 登录 sys 用户,必须指定 sysdba 或 sysoper 身份
sqlplus system/orcl -- 数据库管理员
create user vip identified by vip; -- 注意,新创建的用户,什么权限都没有,需要授权后才能使用
grant create session to vip; -- 授予登录的权限
grant connect to vip; -- 角色是很多权限的打包,connect 是一种角色,它包含了连接查看数据的一些基本权限
grant dba to vip; -- dba 是绝大多数权限的集合,它基本能做所有事情,所以很少单独授予用户。但在测试环境中,这样,很爽。
-- 上面的创建用户、授予权限两步操作,可以简化为下面一步:
grant dba to vip identified by vip; -- 注意,使用分号结尾
sqlplus vip/vip -- 在 cmd 下
conn vip/vip -- 在 sqlplus 中
create table aaa (id int);
alter user scott account unlock;
conn scott/tiger
alter user scott identified by [newpassword];
这是一个轻量级的功能强大的客户端, 是 dba 必须掌握的工具。
我们可以配置 sqlplus 的一些行为,两个命令:
比如:
show all -- 显示所有配置参数
show lines -- 显示 lines 的配置信息
show errors -- 显示错误
set lines[ize] 333 -- 将行宽设置为 333
set pages[ize] 444 -- 将每页的记录数设置为 444
set echo off/on -- 导入外部文件,是否要显示原始 sql 语句
set feedback on/off -- 是否显示“查询到xx数据”等信息
set timing on/off -- 是否显示语句的执行时间
set autocommit on/off -- 是否启用自动提交
set autotrace on/off -- 是否输出执行计划
set serverouput on/off -- 是否显示来自服务端的信息
column aaa format a22 -- 将列 ‘aaa‘ 的宽度限制为 22 个字幕‘a‘的大小。column 命令很强大,语句也复杂,此处不提。
在 sqlplus 中有缓冲区的概念:
缓冲区是用来记录上一次执行的命令语句的空间。
我们可以通过一些列简单命令,对上一次输入的语句进行一些控制:
append/insert
delete
change
list
run
或者 /
例子:
list -- 显示完整的缓存区
list 3 -- 显示并定位到第三行
list 3 5 -- 显示第三行到第五行的内容
list last -- 定位到最后一行
list 3
del -- 删除第三行
list 3
append order by sal -- 定位到第三行,然后追加 order by sal
insert order by sal -- 开启新的一行,插入 order by sal
list 3
change /emp/dept -- 定位到第三行,将这一行的 emp 换为 dept
还有其他一些命令:
get D:\aaa.sql -- 将文件加载到缓冲区,但不执行
start D:\aaa.sql -- 将文件加载到缓冲区,并且执行
@D:\aaa.sql -- 是上面一条语句的简写形式
save D:\bbb.sql -- 将缓冲区的内容保存到文件中
edit -- 调用外部编辑器,编辑缓冲区
clear screen -- 清空缓冲区
show user -- 显示当前用户
show parameters -- 显示 oracle 的配置参数
show parameters nls -- 显示 oracle 中所有跟语言配置相关的一些参数
describe emp -- 显示 emp 表的结构信息
oracle基础
标签:cmd 限制 cot 执行计划 ext sys lock 大小 unlock