<%@ page contentType="text/html;charset=windows-1252"%>
<%@ page import= "java.sql.*" %>
<%@ page import= "project1.*" %>
<%@ page import= "java.sql.CallableStatement" %>
<%@ page import= "oracle.jdbc.OracleTypes" %>
<%@ page import= "oracle.jdbc.driver.*" %>
try
{
String selection = "s";
String triple = "(?S ?P ?O)";
String urls = "(urlname='http://localhost/regression.rdf') OR (urlname='http://localhost/technical_girls_and_guys.rdf')";
String query_string = "plat";
int to_ = 1;
int from_ = 10;
JDBConnection jdbc = new JDBConnection();
CallableStatement cstmt = null;
ResultSet cursor = null;
cstmt = jdbc.conn.prepareCall("{call UOC_RDF_QUERY.BQUERY(?,?,?,?,?,?,?)}");
cstmt.setString(1,selection);
cstmt.setString(2,triple);
cstmt.setString(3,urls);
cstmt.setString(4,query_string);
cstmt.setInt(5,to_);
cstmt.setInt(6,from_);
cstmt.registerOutParameter(7,OracleTypes.CURSOR);
cstmt.execute();
cursor = (ResultSet) cstmt.getObject(7);
while (cursor.next())
{
System.out.println("Record: "+cursor.getString(1));
%>
<%
}
cstmt.close();
jdbc.conn.close();
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
%>
Search This Blog
Sunday, November 23, 2008
How to use Refence Cursor in Oracle
--- Tested enviroment Oracle11g
---- Win Xp
CREATE OR REPLACE PACKAGE A1 IS
PROCEDURE test(result_ OUT SYS_REFCURSOR);
END A1;
/
CREATE OR REPLACE PACKAGE BODY A1
AS
PROCEDURE test(result_ OUT SYS_REFCURSOR)
IS
BEGIN
OPEN result_ FOR SELECT C1 FROM VARCHARTAB;
END test;
end ;
/
INSERT INTO VARCHARTAB VALUES (' Michael Georgiou');
commit;
declare
result_ SYS_REFCURSOR;
r varchar2(4000);
begin
A1.test(result_);
LOOP
FETCH result_ INTO r;
EXIT WHEN result_%NOTFOUND;
dbms_output.put_line(r);
END LOOP;
CLOSE result_;
end;
/
---- Win Xp
CREATE OR REPLACE PACKAGE A1 IS
PROCEDURE test(result_ OUT SYS_REFCURSOR);
END A1;
/
CREATE OR REPLACE PACKAGE BODY A1
AS
PROCEDURE test(result_ OUT SYS_REFCURSOR)
IS
BEGIN
OPEN result_ FOR SELECT C1 FROM VARCHARTAB;
END test;
end ;
/
INSERT INTO VARCHARTAB VALUES (' Michael Georgiou');
commit;
declare
result_ SYS_REFCURSOR;
r varchar2(4000);
begin
A1.test(result_);
LOOP
FETCH result_ INTO r;
EXIT WHEN result_%NOTFOUND;
dbms_output.put_line(r);
END LOOP;
CLOSE result_;
end;
/
Wednesday, June 25, 2008
Monday, June 23, 2008
Find the name of an oracle instance,or if the instance is up
$ ps -ef | grep ora_smon
oracle 8711 8669 0 16:15 pts/1 00:00:00 grep ora_smon
$ cat /etc/oratab
....
orcl:/home/oracle/10.1:Y
...
$cd $ORACLE_HOME/dbs
$ls -l spfile*
oracle 8711 8669 0 16:15 pts/1 00:00:00 grep ora_smon
$ cat /etc/oratab
....
orcl:/home/oracle/10.1:Y
...
$cd $ORACLE_HOME/dbs
$ls -l spfile*
Check if database is up ( ksh script)
#!/bin/ksh
if ps -aef | grep pmon | grep rdev > /dev/null ; then
print "Database is Up."
else
print "Database is down."
exit 1
fi
if ps -aef | grep pmon | grep rdev > /dev/null ; then
print "Database is Up."
else
print "Database is down."
exit 1
fi
Drop Corrupted Undo Tablespace with active Rollback Segments
1, Make sure the database was last cleanly shut down.
sqlplus /nolog
SQL>connect sys/change@crm as sysdba
SQL> shutdown immediate
2, mount database in RESTRICT mode, using pfile.
SQL> STARTUP RESTRICT MOUNT pfile=C:\Oracle\job\crmstandby\initCRM_18.ora
ORACLE instance started. Total System Global Area 1620126452 bytes
Fixed Size 457460 bytes
Variable Size 545259520 bytes
Database Buffers 1073741824 bytes
Redo Buffers 667648 bytes
Database mounted.
3, Try to offline drop the bad datafile.
SQL> ALTER DATABASE DATAFILE 'K:\ORADATA\CRM\UNDOTBS2_02.DBF' OFFLINE DROP;
*
ERROR at line 1:
ORA-01548: active rollback segment ‘_SYSSMU11$’ found, terminate dropping
tablespace
or this SQL:
DROP TABLESPACE undotbs2 INCLUDING CONTENTS AND DATAFILES ;
*
ERROR at line 1:
ORA-01548: active rollback segment ‘_SYSSMU11$’ found, terminate dropping
tablespace
4, Use this query to see how many rollback segments were corrupted:
SQL>select segment_name,status,tablespace_name from dba_rollback_segs where status='NEEDS RECOVERY';
SEGMENT_NAME STATUS TABLESPACE_NAME
—————————— —————- —————–
_SYSSMU11$ NEEDS RECOVERY UNDOTBS2
_SYSSMU12$ NEEDS RECOVERY UNDOTBS2
_SYSSMU13$ NEEDS RECOVERY UNDOTBS2
_SYSSMU14$ NEEDS RECOVERY UNDOTBS2
_SYSSMU15$ NEEDS RECOVERY UNDOTBS2
_SYSSMU16$ NEEDS RECOVERY UNDOTBS2
_SYSSMU17$ NEEDS RECOVERY UNDOTBS2
_SYSSMU18$ NEEDS RECOVERY UNDOTBS2
_SYSSMU19$ NEEDS RECOVERY UNDOTBS2
_SYSSMU20$ NEEDS RECOVERY UNDOTBS2
5, Add the following line to pfile:
_corrupted_rollback_segments =('_SYSSMU11$','_SYSSMU12$','_SYSSMU13$','_SYSSMU14$','_SYSSMU15$','_SYSSMU16$','_SYSSMU17$','_SYSSMU18$','_SYSSMU19$','_SYSSMU20$')
Make sure you uncomment “undo_management=AUTO”, and specify you want to use UNDOTBS1 as undo tablespace.
#undo_management=AUTO
undo_tablespace=UNDOTBS1
6, Start the database again:
SQL> STARTUP RESTRICT MOUNT pfile=C:\Oracle\job\crmstandby\initcrm_18.ora
7. Drop bad rollback segments
SQL> drop rollback segment "_SYSSMU11$";
Rollback segment dropped.
…
SQL> drop rollback segment "_SYSSMU20$";
Rollback segment dropped.
8, Check again
SQL> select segment_name,status,tablespace_name from dba_rollback_segs;
SEGMENT_NAME STATUS TABLESPACE_NAME
—————————— —————- —————
SYSTEM ONLINE SYSTEM
_SYSSMU2$ ONLINE UNDOTBS1
_SYSSMU3$ ONLINE UNDOTBS1
_SYSSMU4$ ONLINE UNDOTBS1
_SYSSMU5$ ONLINE UNDOTBS1
_SYSSMU6$ ONLINE UNDOTBS1
_SYSSMU7$ ONLINE UNDOTBS1
_SYSSMU8$ ONLINE UNDOTBS1
_SYSSMU9$ ONLINE UNDOTBS1
_SYSSMU10$ ONLINE UNDOTBS1
_SYSSMU21$ ONLINE UNDOTBS1
9. Now drop bad undo TABLESPACE UNDOTBS2;
SQL> drop TABLESPACE UNDOTBS2;
10, Recreate the undo rollback tablespace with all its rollback segments
SQL>CREATE UNDO TABLESPACE UNDOTBS1 DATAFILE 'K:\oradata\CRM\UNDOTBS01.DBF' SIZE 2000M reuse AUTOEXTEND ON ;
11, Change undo tablespace
ALTER SYSTEM SET undo_tablespace = UNDOTBS1 ;
12. Remove the following line from pfile
_corrupted_rollback_segments =('_SYSSMU11$','_SYSSMU12$','_SYSSMU13$','_SYSSMU14$','_SYSSMU15$','_SYSSMU16 $','_SYSSMU17$','_SYSSMU18$','_SYSSMU19$','_SYSSMU20$')
and uncomment “undo_management=AUTO”
undo_management=AUTO
undo_retention=10800
undo_tablespace=UNDOTBS1
13, Shutdown database
SQL>shutdown immediate;
14, Edit initCRM_18.ora, make sure you change ‘undo_tablespace=UNDOTBS2? to “undo_tablespace=UNDOTBS1?, then start oracle database:
sqlplus /nolog
SQL>connect sys/change@crm as sysdba
SQL> STARTUP RESTRICT MOUNT pfile=C:\Oracle\job\crmstandby\initcrm_18.ora
ORACLE instance started.
Total System Global Area 1620126452 bytes
Fixed Size 457460 bytes
Variable Size 545259520 bytes
Database Buffers 1073741824 bytes
Redo Buffers 667648 bytes
Database mounted.
Database opened.
15, Create Undo tablespace:
SQL>CREATE UNDO TABLESPACE UNDOTBS2 DATAFILE 'K:\oradata\CRM\UNDOTBS02.DBF' SIZE 2000M reuse AUTOEXTEND ON ;
SQL>DROP TABLESPACE undotbs1 INCLUDING CONTENTS AND DATAFILES ;
16, Startup database with spfile
SQL> startup;
ORACLE instance started.
Total System Global Area 1620126452 bytes
Fixed Size 457460 bytes
Variable Size 545259520 bytes
Database Buffers 1073741824 bytes
Redo Buffers 667648 bytes
Database mounted.
Database opened.
sqlplus /nolog
SQL>connect sys/change@crm as sysdba
SQL> shutdown immediate
2, mount database in RESTRICT mode, using pfile.
SQL> STARTUP RESTRICT MOUNT pfile=C:\Oracle\job\crmstandby\initCRM_18.ora
ORACLE instance started. Total System Global Area 1620126452 bytes
Fixed Size 457460 bytes
Variable Size 545259520 bytes
Database Buffers 1073741824 bytes
Redo Buffers 667648 bytes
Database mounted.
3, Try to offline drop the bad datafile.
SQL> ALTER DATABASE DATAFILE 'K:\ORADATA\CRM\UNDOTBS2_02.DBF' OFFLINE DROP;
*
ERROR at line 1:
ORA-01548: active rollback segment ‘_SYSSMU11$’ found, terminate dropping
tablespace
or this SQL:
DROP TABLESPACE undotbs2 INCLUDING CONTENTS AND DATAFILES ;
*
ERROR at line 1:
ORA-01548: active rollback segment ‘_SYSSMU11$’ found, terminate dropping
tablespace
4, Use this query to see how many rollback segments were corrupted:
SQL>select segment_name,status,tablespace_name from dba_rollback_segs where status='NEEDS RECOVERY';
SEGMENT_NAME STATUS TABLESPACE_NAME
—————————— —————- —————–
_SYSSMU11$ NEEDS RECOVERY UNDOTBS2
_SYSSMU12$ NEEDS RECOVERY UNDOTBS2
_SYSSMU13$ NEEDS RECOVERY UNDOTBS2
_SYSSMU14$ NEEDS RECOVERY UNDOTBS2
_SYSSMU15$ NEEDS RECOVERY UNDOTBS2
_SYSSMU16$ NEEDS RECOVERY UNDOTBS2
_SYSSMU17$ NEEDS RECOVERY UNDOTBS2
_SYSSMU18$ NEEDS RECOVERY UNDOTBS2
_SYSSMU19$ NEEDS RECOVERY UNDOTBS2
_SYSSMU20$ NEEDS RECOVERY UNDOTBS2
5, Add the following line to pfile:
_corrupted_rollback_segments =('_SYSSMU11$','_SYSSMU12$','_SYSSMU13$','_SYSSMU14$','_SYSSMU15$','_SYSSMU16$','_SYSSMU17$','_SYSSMU18$','_SYSSMU19$','_SYSSMU20$')
Make sure you uncomment “undo_management=AUTO”, and specify you want to use UNDOTBS1 as undo tablespace.
#undo_management=AUTO
undo_tablespace=UNDOTBS1
6, Start the database again:
SQL> STARTUP RESTRICT MOUNT pfile=C:\Oracle\job\crmstandby\initcrm_18.ora
7. Drop bad rollback segments
SQL> drop rollback segment "_SYSSMU11$";
Rollback segment dropped.
…
SQL> drop rollback segment "_SYSSMU20$";
Rollback segment dropped.
8, Check again
SQL> select segment_name,status,tablespace_name from dba_rollback_segs;
SEGMENT_NAME STATUS TABLESPACE_NAME
—————————— —————- —————
SYSTEM ONLINE SYSTEM
_SYSSMU2$ ONLINE UNDOTBS1
_SYSSMU3$ ONLINE UNDOTBS1
_SYSSMU4$ ONLINE UNDOTBS1
_SYSSMU5$ ONLINE UNDOTBS1
_SYSSMU6$ ONLINE UNDOTBS1
_SYSSMU7$ ONLINE UNDOTBS1
_SYSSMU8$ ONLINE UNDOTBS1
_SYSSMU9$ ONLINE UNDOTBS1
_SYSSMU10$ ONLINE UNDOTBS1
_SYSSMU21$ ONLINE UNDOTBS1
9. Now drop bad undo TABLESPACE UNDOTBS2;
SQL> drop TABLESPACE UNDOTBS2;
10, Recreate the undo rollback tablespace with all its rollback segments
SQL>CREATE UNDO TABLESPACE UNDOTBS1 DATAFILE 'K:\oradata\CRM\UNDOTBS01.DBF' SIZE 2000M reuse AUTOEXTEND ON ;
11, Change undo tablespace
ALTER SYSTEM SET undo_tablespace = UNDOTBS1 ;
12. Remove the following line from pfile
_corrupted_rollback_segments =('_SYSSMU11$','_SYSSMU12$','_SYSSMU13$','_SYSSMU14$','_SYSSMU15$','_SYSSMU16 $','_SYSSMU17$','_SYSSMU18$','_SYSSMU19$','_SYSSMU20$')
and uncomment “undo_management=AUTO”
undo_management=AUTO
undo_retention=10800
undo_tablespace=UNDOTBS1
13, Shutdown database
SQL>shutdown immediate;
14, Edit initCRM_18.ora, make sure you change ‘undo_tablespace=UNDOTBS2? to “undo_tablespace=UNDOTBS1?, then start oracle database:
sqlplus /nolog
SQL>connect sys/change@crm as sysdba
SQL> STARTUP RESTRICT MOUNT pfile=C:\Oracle\job\crmstandby\initcrm_18.ora
ORACLE instance started.
Total System Global Area 1620126452 bytes
Fixed Size 457460 bytes
Variable Size 545259520 bytes
Database Buffers 1073741824 bytes
Redo Buffers 667648 bytes
Database mounted.
Database opened.
15, Create Undo tablespace:
SQL>CREATE UNDO TABLESPACE UNDOTBS2 DATAFILE 'K:\oradata\CRM\UNDOTBS02.DBF' SIZE 2000M reuse AUTOEXTEND ON ;
SQL>DROP TABLESPACE undotbs1 INCLUDING CONTENTS AND DATAFILES ;
16, Startup database with spfile
SQL> startup;
ORACLE instance started.
Total System Global Area 1620126452 bytes
Fixed Size 457460 bytes
Variable Size 545259520 bytes
Database Buffers 1073741824 bytes
Redo Buffers 667648 bytes
Database mounted.
Database opened.
Subscribe to:
Posts (Atom)