`
zhangfeilo
  • 浏览: 402125 次
  • 性别: Icon_minigender_1
  • 来自: 昆明
社区版块
存档分类
最新评论

oracle记录

    博客分类:
  • DB
 
阅读更多
37

oracle记录

create tablespace lottery datafile --建立表空间
'D:\oracle\product\10.2.0\oradata\dzw\lottery.dbf' 
size 50m reuse autoextend on next 56k maxsize 100m;
---------------------------------------
drop tablespace ssscms including contents and datafiles;
---------------------------------------
create user dongzhiwei identified by admin; --创建用户
---------------------------------------
create user dongzhiwei identified by admin default tablespace lottery; --创建用户并指定表空间
---------------------------------------
grant dba to dongzhiwei; --授权
---------------------------------------
drop user a cascade;
---------------------------------------
imp dongzhiwei/admin file='d:/lottery.dmp' full=y; --导入备份数据
exp dongzhiwei/admin file='d:/test.dmp' oner=(dongzhiwei); --导出备份
exp dongzhiwei/admin file='d:/test.dmp' oner=(dongzhiwei) rows=n --不导出数据
---------------------------------------
create table s3d( --创建表
id int,
at int,
num char(3),
num1 int,
num2 int,
num3 int,
dt date,
constraint pk_id primary key (id)); --添加主建约束
---------------------------------------
alter table s3d modify num1 int; --修改表num1列的类型
update s3d set num = num1||num2||num3 --连接字符串
---------------------------------------
set serveroutput on --启动服务器输出
declare --最简单的plsql程序块
begin
dbms_output.put_line('abc');
end;
/
---------------------------------------
declare ---定义变量与for循环
    i constant int := 10;
    j int ;
begin
    for j in 1..i loop
            dbms_output.put_line(j);
    end loop;
end;
/
---------------------------------------
declare
   i constant int := 10; --定义常量
   j int ;
   num char(3);
begin
   for j in 1..i loop
           select num into num from s3d where id = j; --从数据库中查询值赋予变量
           dbms_output.put_line(num);
   end loop;
end;
/
---------------------------------------
declare
   num s3d.num%type; --使用%type定义变量类型
begin
   select num into num from s3d where id =123;
   dbms_output.put_line(num);
end;
/
---------------------------------------
declare
   type typetest is record( --定义记录类型变量
           num s3d.num %type,
           dt date
);
   mytype typetest; --自己定义的类型
begin
   select num,dt into mytype from s3d where id =1;
   dbms_output.put_line(mytype.num||' '||mytype.dt);
end;
/
---------------------------------------
declare
    testtable s3d %rowtype; --用rowtype
begin
    select * into testtable from s3d where id=1;
    dbms_output.put_line(testtable.num);
end;
/
--------------------------------------
declare
s int:=0;
i int:=1;
begin
    loop --loop exit when
    s:=s+i;
    i:=i+1;
    exit when i>100;
end loop;
dbms_output.put_line(s);
end;
   ---------------------------------------
declare
s int:=0;
i int:=1;
begin
    while i<=100 loop --while loop ..end loop
            s:=s+i;
            i:=i+1;
    end loop;
dbms_output.put_line(s);
end;
   ---------------------------------------
   declare -- for in loop... end loop
s int:=0;
i int:=1;
begin
    for i in 1..100 loop
            s:=s+i;
    end loop;
dbms_output.put_line(s);
end;
---------------------------------------
declare --游标与多维表配合使用
type tt is table of s3d%rowtype index by binary_integer;
t tt; --自定义的多维表
cursor cs is
    select * from pt order by id desc;
i int := 0;
begin
open cs;
loop
    exit when cs%notfound;
    fetch cs --把游标中的数全部放放多维表t中
      into t(i);
    i := i + 1;
end loop;
close cs;
dbms_output.put_line(t.count);
for i in 0..t.count-2 loop --按顺序取多维表中的数
      dbms_output.put_line(t(i).id||' '||t(i+1).id||' '||(t(i).id-t(i+1).id));
      --dbms_output.put_line(t(i).num||' '||t(i+1).num||' '||(t(i).id-t(i+1).id));
end loop;
end;
---------------------------------------
sign(n)--n>0返回1 n=0返回0 n<0返回-1
ceil(n)--大于等于n的最小整数
floor(n)--小于等于n的最大整数
round(n1,n2)----四舍五入带n2位小数的n1,不指定n2默认为0
trunc(n1,n2)--截去部分小数位,使剩下n2位小数,不四舍五入
mod(n1,n2)--n1与n2的余数
---------------------------------------
select num,count(*) from s3d group by num having count(*)>5;--查询出现超过5次的数
---------------------------------------
select table_name from dba_tables where owner='DONGZHIWEI';--查询我自己的表所有的表名
--------------------------------------
declare
   i int :=0;
   j int :=0;
   k int :=0;
   s int :=0;
begin
   for i in 0..9 loop
           for j in 0..9 loop
                   for k in 0..9 loop
                           insert into allNum(id,num) values(s,i||j||k);
                           s:=s+1;
                   end loop;
           end loop;
   end loop;
end;
/
//反向取
declare
begin
for i in reverse 1..5 loop
dbms_output.put_line(i);
end loop;
end;
/
--------------------------------------
create table pt as select * from s3d where 1=2;--创建和现有表一致的表 ,不插入数据
insert into pt select * from s3d where id=1
--------------------------------------
select id,num,--case when then 结构 ,注意case之前的逗号
case
when id=1 then '111'
when id=2 then '222'
else 'else'
end
from s3d where id<5;
----------------------------------------
select id,num, --decode语句,注意decode之前的逗号
decode(id,1,'111',2,'222',3,'333','else') from s3d where id<5;
---------------------------------------- 
create table t0(id int primary key);--设定主键
create table t1(id int,constraint pk_t1_id primary key(id));--对主键操作
alter table t1 drop constraint pk_t1_id; --去掉主键
alter table t1 add constraint pk_t1_id primary key(id);--添加主键
alter table t1 disable constraint pk_t1_id;--使主键约束无效,此时可插入相同主键值
alter table t1 enable constraint pk_t1_id;--使主键约束生效

create table t2(id int,t1id,--建表,指定外键
constraint fk_t1_id foreign key(t1id) reference --指定t1id为外键 级联删除
s t1(id) on delete cascade);

alter table t2 drop constraint fk_t1_id;--删除外键
alter table t2 add constraint fk_t1_id foreign key(id) references t1(id)--添加外键
on delete set null;

create table t3(sex char(2),constraint ck_sex check(sex='男' or sex='女')); --添加check约束
create table t3(sex char(2) check(sex='男' or sex='女'));--添加check约束
---------------------------------------- 
update s3d set sj='0'||trim(sj) where length(trim(sj))=2; --去掉空格并在前面改成0
---------------------------------------- 
select trunc(134.91) from dual; --去掉小数部分,不四舍五入
---------------------------------------- 
select dbms_random.value(100,999) from dual; --100到999间的随机数
select dbms_random.string('u',3) from dual; --三个小写随机字符
--'u','U' : 大写 a-z 
    --'l','L' : 小写 a-z
    --'a','A' : 任意大写(小写)a-z 
    --'x','X' : 小写和数字
    --'p','P' : 任意可打印字符

---------------------------------------创建生成指定位数的随机整数
create or replace function random(num int:=3) return int is
s int:=1;
e int:=9;
begin
for i in 1..abs(abs(num)-1) loop
   s:=s||'0';
   e:=e||'9';
end loop;
return trunc(dbms_random.value(s,e));
end;
---------------------------------------- 授权给用户执行函数的权限
conn 
grant execute on random to tu1;
grant execute on dbms_lock to USERNAME;
select system.random from dual;
----------------------------------------
declare 
begin 
for i in 1..10 loop 
   dbms_output.put_line(i);
   dbms_lock.sleep(0.5);--使Pl/sql暂停1秒
end loop; 
end; 
----------------------------------------
select user#,name,password from user$ where name='D';
update user$ set name='A' where name = 'D';
----------------------------------------
在PL/SQL中执行DDL语句,用双单引号进行转义
execute immediate sql;
dbms_utility.exec_ddl_statement('sql');

declare
begin
execute immediate 'delete from place_province p where p.id=''12345''';
--dbms_utility.exec_ddl_statement('delete from place_province p where p.id=''12345''');
commit;
end;
----------------------------------------
oracle中使用hibernate时,基本类型在java文件和hbm文件中要配置为对象类型,否则常会报 Null value was assigned to a property of primitive
----------------------------------------
select to_date('2009-10-07 04:12:40','yyyy-mm-dd hh:mi:ss') from dual;
----------------------------------------
select to_char(sysdate,'yyyy"年"mmddhhmiss') from dual;
----------------------------------------
select to_number('$1,600.00','$99,999.00') from dual;
----------------------------------------
select nullif(2,null) from dual;--2
select nullif(2,2) from dual;-- null
----------------------------------------
select coalesce(null,null,3) from dual; --3
----------------------------------------
select decode(2,1,'111',2,'222') from dual;--222
select decode(3,1,'111',2,'222','333') from dual;
select sum(decode(num,'125',1,0)),sum(decode(num,'248',1,0)) from s3d;
----------------------------------------
select case 1 when 1 then '111' when 2 then '222' else '333' end from dual; --111
select 1, case 1 when 1 then '111' when 2 then '222' else '333' end from dual; -- 1 111
---------------------------------------- for使用
declare
cursor cs is
select * from s3d where rownum<5;
begin
for i in cs loop
dbms_output.put_line(i.num);
end loop;
end;

declare
begin
for i in (select * from s3d where rownum<5) loop
dbms_output.put_line(i.num);
end loop;
end;
----------------------------------------
select table_name from user_tables;--查看当前用户的表
select table_name from all_tables;--查看所有用户的表名
select table_name from dba_tables;--查看所有表名(其中包括系统表)
select * from tab/dba_tables/dba_objects/cat;--查看所有的表
----------------------------------------
相当于alias(别名),比如把user1.table1在user2中建一个同义词table1 
create synonym table1 for user1.table1; 
这样在user2中查select * from table1时就相当于查select * from user1.table1; 
----------------------------------------
查看数据归档模式:(要用dba身份)
archive log list;
设置日志为归档方式:
1. alter system set log_archive_start=true scope=spfile;
2. shutdown immediate
3. startup mount
4. alter database archivelog; (启用) 关闭则为 alter database noarchivelog;
5. alter database open;
----------------------------------------
热备份:
1. alter tablespace lottery begin backup;
2. copy数据库dbf文件到备份路径
3. alter tablespace lottery end backup;
4. alter system archive log current;
5. alter system switch logfile;
6. alter system switch logfile;(切换两次)
7. shutdown immediate;
8. 删除dbf数据文件
9. startup
ORA-01157: 无法标识/锁定数据文件 5 - 请参阅 DBWR 跟踪文件
ORA-01110: 数据文件 5: 'E:\ORACLE\PRODUCT\10.2.0\ORADATA\DZW\LOTTERY.DBF'
10. select * from v$recover_file; --找丢失的数据文件号
11. alter database datafile 5 offline drop; --使数据文件脱机并删除文件
12. alter database open;
13. 把备份的文件拷回到数据库文件路径
14. recover datafile 5;
15. auto--指定日志为auto
16. alter database datafile 5 online;
----------------------------------------
重建控制文件:
备份控制文件里STARTUP NOMOUNT到ALTER DATABASE OPEN;之间的内容:control.txt
运行控制文件:@控制文件
----------------------------------------
重建日志文件:
recover database until cancel;--基于取消的恢复
alter database epen resetlogs;
----------------------------------------
select * from org start with org_id = 872 connect by prior org_id = parent_org_id;--start with connect by prior
----------------------------------------
SQL> startup
ORA-32004: obsolete and/or deprecated parameter(s) specified
ORACLE 例程已经启动。

Total System Global Area 612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             171969412 bytes
Database Buffers          432013312 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
ORA-16038: 日志 2 序列号 57 无法归档
ORA-19809: 超出了恢复文件数的限制
ORA-00312: 联机日志 2 线程 1: 'E:\ORACLE\PRODUCT\10.2.0\ORADATA\DZW\REDO02.LOG'
SQL> select group#,sequence#,archived,status from v$log;

    GROUP# SEQUENCE# ARC STATUS
---------- ---------- --- ----------------
         1         59 NO CURRENT
         3         58 NO INACTIVE
         2         57 NO INACTIVE

SQL> alter database clear unarchived logfile group 3;
数据库已更改。
SQL> shutdown immediate
ORA-01109: 数据库未打开
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup
ORA-32004: obsolete and/or deprecated parameter(s) specified
ORACLE 例程已经启动。

Total System Global Area 612368384 bytes
Fixed Size                  1250428 bytes
Variable Size             171969412 bytes
Database Buffers          432013312 bytes
Redo Buffers                7135232 bytes
数据库装载完毕。
数据库已经打开。
SQL>
----------------------------------------
SQL> show parameter db_recovery
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest                string      D:\oracle\product\10.2.0/flash _recovery_area
db_recovery_file_dest_size           big integer 2G
SQL> alter system set db_recovery_file_dest_size=3G scope=both;--增大日志文件
系统已更改。
SQL> alter database open;
----------------------------------------
truncate table ts;--截短表数据
----------------------------------------
--分页查询
SQL> select * from (select a.*,rownum rn from (select name from users) a where rownum<=10) b where b.rn>=6;
--删除重复记录:
delete from ts t where t.rowid<(select max(rowid) from ts t2 where t.id=t2.id);
----------------------------------------
--查询资源里的某个文本
select * from all_source where text like '%rpt_owe_min_age_02%';
-- 查询对象(table,procedure,package...)
select * from all_objects;    
----------------------------------------
select 1 from dual where decode(1,1,1,0)=1;
select 1 from dual where (case when 1=1 then 1 else 0 end) = 1;
----------------------------------------

 

分享到:
评论

相关推荐

    oracle记录存储过程日志的方法

    本包用于记录存储过程里面的日志,将日志信息写入日志表(mylog)。可以记录日志时间、过程名称、过程里面记录日志的行数、参数值。如果在异常处理部分记录日志,还可以记录异常代码、异常...本人使用开发环境为oracle10g

    Oracle返回记录集.docx

    Oracle数据库允许存储过程返回记录集,这在处理复杂业务逻辑时非常有用,特别是当你需要从数据库获取一组数据并在应用程序中进一步处理时。本篇将详细解释如何使用.NET框架调用Oracle存储过程来获取记录集。 首先,...

    查看登录oracle数据库用户记录.docx

    "查看登录 Oracle 数据库用户记录" Oracle 数据库是一个强大的关系型数据库管理系统,提供了强大的数据存储和管理功能。为了管理和监控数据库的访问情况,需要对登录 Oracle 数据库的用户记录进行跟踪和查看。本文...

    ORACLE多行记录合并

    多行记录合并 采用的是方法4,希望对你们有用

    ORACLE中科学计数法显示问题的解决

    "ORACLE中科学计数法显示问题的解决" 在 Oracle 中,科学计数法显示问题是一个常见的问题,特别是在 PLSQL 中显示超长数字的时候,会出现科学计数法的显示格式。本文档将为解决这个问题提供解决方法。 在 Oracle ...

    Oracle多行记录合并

    在Oracle数据库中,多行记录的合并通常是为了将相同字段的多行数据整合成一行,以便于数据分析或者简化展示。这种操作在报表制作、数据整理等场景中非常常见。本篇文章将详细介绍Oracle中实现多行记录合并的几种方法...

    Flume 抽取MYSQL Oracle数据 JSON格式 推送Kafka

    Flume二次开发,支持抽取MYSQL Oracle数据库数据 以JSON格式推送至Kafka。 demo: sql_json.sources.sql_source.type = com.hbn.rdb.source.SQLSource sql_json.sources.sql_source.connectionurl = jdbc:oracle:...

    oracle查看表历史记录-Oracle查看表操作历史记录并恢复.pdf

    Oracle 查看表历史记录和恢复 Oracle 数据库是一种关系型数据库管理系统,具有强大的数据存储和管理能力。然而,在实际操作中,数据库管理员或开发者可能会不小心删除了重要数据,这时候如何恢复这些数据成了一个...

    Direct Oracle Access v4.1.3 bcb6

    TOracleDataSet ——该数据集组件支持Oracle记录锁定、记录刷新、服务器生成值、自动队列值生成、BLOB压缩。如果主表和从表之间存在外来关键字,或主表含有一个或多个列或属性(网表或varray),那么主从复合关系将...

    彻底删除oracle

    - **清理Event Log中的Oracle记录:** - `HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application`下删除与Oracle有关的条目。 - **检查路径变量:** - 打开系统属性中的“高级系统设置”,...

    oracle中文版

    8. **归档日志模式**:在归档日志模式下,Oracle记录所有的事务,以便在发生故障时能进行完整的恢复。 9. **联机重做日志**:联机重做日志记录了所有改变数据库的事务信息,用于在系统崩溃后恢复数据。 10. **分区...

    oracle中记录用户登录信息的触发器的例子

    ### Oracle中记录用户登录信息的触发器实例解析 #### 一、背景介绍 在Oracle数据库管理中,确保数据安全是一项至关重要的任务。其中,记录用户的登录信息(如登录时间、用户名和客户端IP地址等)可以帮助管理员更...

    ORACLE存储中记录日志

    自已写的可在ORACLE存储过程中记录运行日志工具包,调用方便简单。

    Oracle数据访问 获取记录总数

    本篇文章将深入探讨如何在Visual C++ 6.0(简称VC6)环境下,利用MFC(Microsoft Foundation Classes)和OO4O(Object for OLE Automation for Oracle)库来访问Oracle数据库并获取记录总数。 首先,我们需要理解...

    记录被另一个用户锁定.txt

    ### Oracle记录被另一个用户锁定的解决办法 在Oracle数据库中,当多个用户尝试同时更新同一数据记录时,可能会出现锁定冲突的问题。这种情况下,如果一个用户的事务已经锁定了某些记录,而其他用户试图修改这些记录...

    教案Oracle数据库卸载.pdf

    11. **删除系统日志中的Oracle记录**:在事件查看器中,清除所有Oracle相关的日志条目,以便彻底摆脱Oracle的痕迹。 12. **处理遗留的DLL文件**:如果在卸载过程中遇到无法删除的动态链接库文件(DLL),重启计算机...

    oracle12c安装过程记录

    Oracle 12c 安装过程记录 Oracle 12c 是甲骨文公司最新推出的关系型数据库管理系统,具有高性能、安全性好、可靠性强等特点。在本文中,我们将详细记录 Oracle 12c 的安装过程,并提供相关的截图,以便读者更好地...

Global site tag (gtag.js) - Google Analytics