设为首页 收藏本站
查看: 581|回复: 0

[经验分享] oracle 学习笔记下

[复制链接]

尚未签到

发表于 2016-7-6 09:48:00 | 显示全部楼层 |阅读模式
建立表空间:建立表空间使用create tablespace 命令
只有拥有dba 或是拥有create datebase权限的用户可以创建

SQL>  create tablespace demon001 datafile 'd:\demon001.dbf' size 2m uniform size 128k;(这里的

uniform就是我们所指的区)


向指定表空间中添加表
create table mypart(deptno number(4),dname varchar2(14),loc varchar2(13)) tablespace demon001;

改变表空间状态 一般还是特权用户或是dba

(1)使表空间脱机
alter tablespace 表空间名 offline

(2)使表空间联机
alter tablespace 表空间名 online

(3)只读表空间,当建立表空间时,表空间可以读写,如果不希望该表空间上执行update,delete
,insert 操作,那么可以将表空间改为只读状态
alter tablespace  表空间名 read only;
如果要恢复则    alter tablespace  表空间名 read write;

(4)知道表空间得到其下面的表
select * from all_tables where tablespace_name='DEMON001';


(5) 知道一个表,查看属于哪个表空间
SQL> select tablespace_name,table_name from user_tables where table_name='表名';

(6)删除表空间
drop tablespace '表空间名' Including contends and datafiles;
说明:在删除表空间时,会把所有的数据对象和数据库文件也删除;

(7)当表空间达到足够大时,就增加不了数据了。这时候可以使用三种方式来增加表空间大小;
a.增加数据文件的数量
alter tablespace demon001 add datafile 'd:\demon002.dbf' size 20m;

b.增加数据文件大小
alter tablespace '表空间名' resize 20m;

c.设置文件的自动增长
alter tablespace '表空间名' autoextend on next 10m maxsize 500m;

(8)移动数据文件
如果你的数据文件所在的磁盘损坏时,该数据文件将不再使用,为了能够重新使用,需要将这些文件的副本移动到

其他磁盘,然后恢复
下面以demon001.dbf 为例说明 :
a.确定数据文件所在的表空间
select tablespace_name from dba_data_files where file_name='d:\demon001.dbf';

b.使表空间脱机,确保数据文件的一致性,将表空间转换为offline的状态
alter tablespace demon001 offline;

c.使用命令移动数据文件到指定的目标位置
host move d:\demon001.dbf  e:\demon001.dbf

d.在物理上移动数据后,还必须执行alter tablespace 命令对数据文件进行逻辑修改
alter tablespace demon001 rename datafile 'd:\demon001.dbf' to 'e:\demon001.dbf';

e.在移动数据文件后,为了使用户可以访问该表空间,必须将其转化成online状态
alter tablespace '表空间名' online


.权限
1.系统权限 (用户针对数据库的一些操作如建库 建表  创建用户  )
system---》tom授权(登录)--》ken  当回收tom权限时,ken 是否可以再登录
系统权限不是级联回收
2.对象权限(对表的增删改查 ,索引等等操作)
对象权限是级联回收的

角色:是一些相关联权限的结合
预定义角色:是oracle所提供的角色,是执行一些特定的管理任务。
下面介绍三个常见的预定义角色:
a.resource:
b.connect
c.dba
自定义角色:一般是dba或是有create role 权限的用户

create role 角色名 not identified;
grant create session to 角色名 with admin option;
grant select on scott.emp to 角色名;
.........;

授角色(一般是dba 或是拥有grand any role 的权限)
grant 角色名 to 用户 with admin option;

消除角色  drop role  角色名  执行完该命令后,将不会再有登录权限


plsql
存储过程:
create table mytest(username varchar2(10),password varchar2(10));

创建:SQL> create or replace procedure insert_prol is//后面的or replace 是可选的
  2  begin
  3  insert into mytest values('dim','123');
  4  end;
  5  /

删除 drop procedure insert_prol;

执行 exec insert_prol;
     call  insert_prol;


例1:最简单的块

SQL> set serveroutput on;
SQL> begin
  2  dbms_output.put_line('hell');//和java中的包中含有方法和函数相似
  3  end;
  4  /

例2:定义变量(假如输入为7788)

SQL> declare
  2  v_name varchar(9);
  3  v_sal number(5);
  4  begin
  5  select ename,sal into v_name,v_sal from emp where EMPNO=&no;// &是从控制台输入变量
  6  dbms_output.put_line('用户名是:'||v_name||'  工资:'||v_sal);//"||"是连接符
     exception
  7  when no_data_found then
  8  dbms_output.put_line('输入有误!');
  9  end;
  10  /

用户名是:SCOTT  工资:3000

2.1 定义常量的方法:“:=”
SQL>  declare
  2   c_tax_rate number(3,2):=0.03;
  3   v_tax_sal number(7,2);
  4   v_name varchar2(5);
      v_sal number(7,2);
  6   begin
  7   select ename,sal into v_name,v_sal from emp where empno=&no;
  8   v_tax_sal := v_sal*c_tax_rate;
  9   dbms_output.put_line('姓名:'||v_name ||'工资:' ||v_sal ||'纳税:' ||v_tax_sal);
10   end;
11  /

标量:%type 解决字符串的不匹配:
还是上面的例子,如果我们得到的名字的个数大于5 那么就会报错(numeric or value error: character

string buffer too small),这是可以使用
  
  declare
      c_tax_rate number(3,2):=0.03;
  v_tax_sal number(7,2);
    v_name emp.ename%type;//这里是表示该变量的到的buffer大小和emp表中ename的大小相同
   v_sal number(7,2);
   begin
     select ename,sal into v_name,v_sal from emp where empno=&no;
   v_tax_sal := v_sal*c_tax_rate;
     dbms_output.put_line('姓名:'||v_name ||'工资:' ||v_sal ||'纳税:' ||v_tax_sal);
    end;

复合类型--pl/sql 记录实例【相当java中的结构体

declare
--定义一个pl/sql的记录类型emp_record_type 包含三个部分 name,salary,title
type emp_record_type is record(name emp.ename%type,salary emp.sal%type,title emp.job%type);
--定义一个emp_record_type类型的变量
dim_record   emp_record_type;
begin
select ename,sal,job into dim_record from emp where empno=7788;
dbms_output.put_line('该记录的用户名是:'||dim_record.name);
end;

该记录的用户名是:SCOTT
如果没有显示结果,可能是没有设置:set serveroutput on;

复合类型--pl/sql 表实例 【相当java中的数组

SQL>
SQL> declare
  2  --定义一个pl/sql的表类型  存放的类型是:emp.ename%type
  3  --index by binary_integer 表示下标是整数
  4  type emp_table_type is table of emp.ename%type index by binary_integer;
  5  --定义一个emp_table_type类型的变量
  6  dim_table   emp_table_type;
  7  begin
  8  select ename into dim_table(-1) from emp where empno=7788;
  9  dbms_output.put_line('该记录的用户名是:'||dim_table(-1));
10  end;
11  /

该记录的用户名是:SCOTT

【在这里如果把where 后的去掉就会出现错误 ,因为返回的个数大于一 :解决问题如下:使用游标

declare
  2  --定义游标类型dim_emp_cursor
  3  type dim_emp_cursor is ref cursor;
  4  --定义一个游标变量
  5  test_cursor dim_emp_cursor;
  6  --定义变量
  7  v_ename emp.ename%type;
  8  v_sal emp.sal%type;
  9  begin
10  --把test_cursor 和一个select 结合
11  open test_cursor for select ename,sal from emp where deptno=&no;
12  --循环取出
13  loop
14  fetch test_cursor into v_ename,v_sal;
15  exit when test_cursor%notfound;
16  dbms_output.put_line('名字:'||v_ename||'工资:'||v_sal);
17  end loop;
18  --关闭游标
19  close test_cursor;
20  end;
21  /

函数:
create function dim_fun1 (s_name varchar2) return
  2  number is yearSal number(7,2);
  3  begin
  4  select sal*12+nvl(comm,0)*12 into yearSal from emp where ename=s_name;
  5  return yearSal;
  6  end;
  7  /

执行:SQL> var year_sal number;
SQL> call dim_fun1('SCOTT') into:year_sal;

Method called
year_sal
---------
36000


包的创建  包体的创建  及包的使用
create package dim_pag is
  2  procedure update_sal (name varchar2,newSal number);
  3  function total_income(name varchar2) return number;
  4  end;
  5  /

Package created

SQL>
SQL> create package body dim_pag is
  2  procedure update_sal(name varchar2,newSal number)
  3  is
  4  begin
  5  update emp set sal=newSal where ename=name;
  6  end;
  7  function total_income(name varchar2)
  8  return number is
  9  all_sal number;
10  begin
11  select sal*12+nvl(comm,0) into all_sal from emp
12  where ename=name;
13  return all_sal;
14  end;
15  end;
16  /

Package body created

SQL> exec dim_pag.update_sal('SCOTT',200);


带有输入输出参数:
--输入参数 in(默认)    输出参数用out
create or replace procedure dim_inout(v_no in number,v_name out varchar2,v_sal out number)
is
begin
select ename,sal into v_name,v_sal from emp where empno=&v_no;
end;

在java中调用:
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection

("jdbc:oracle:thin:@localhost:1521:ORCL","SCOTT","pass");
CallableStatement cs = con.prepareCall("{call dim_inout(?,?,?)}");
cs.setInt(1, 7788);
//给第二个?赋值
cs.registerOutParameter(2, oracle.jdbc.OracleTypes.VARCHAR);
cs.registerOutParameter(3, oracle.jdbc.OracleTypes.NUMBER);
cs.execute();

String name = cs.getString(2);
double sal = cs.getDouble(3);
System.out.println("7788的用户名是:"+name+"工资是:"+sal);
} catch (Exception e) {
e.printStackTrace();
}



一般情况下,我们使用返回结果集的方式得到

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-240123-1-1.html 上篇帖子: Oracle常用sql(转) 下篇帖子: Oracle常用技巧(转)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表