The task is to upgrade Oracle 10g XE to 11g XE to support our growing application. The application tracks patient information for a government agency. The growing data has been causing performance issue for the present 10g XE. So, management decided to upgrade for 3 reasons, namely:
1. Government requirement that databases for any of its agencies must be operating in 11g or above;
2. For better performance as 10g XE is already dragging due to the explosion of the data; and
3. Oracle will stop supporting 10g XE, so it makes sense to upgrade.
Hardware:
Operating system is Windows XP while database is Oracle 10g XE. Database has 2 main schemas (patient & Doctor). These schemas must be migrated to the new database (11g XE) with all the database objects intact.
Step-by-step guide to Upgrade
1. Export schemas
exp system/*****
owner=patient file=PATIENT.IMP
2. Uninstall ORACLE XE
10g
go to "control
Panel"
uninstall Oraclexe 10g
Delete folder
c:\oraclexe\.....\BIN (If this was not deleted by the uninstall operation)
data:image/s3,"s3://crabby-images/6dcd9/6dcd996f31846f543533d200e59dd963c5acaa56" alt=""
Accept the Licensing agreement
data:image/s3,"s3://crabby-images/e3f9d/e3f9d6971e52031a370f21306034f0877253e8a1" alt=""
Enter password for SYS and SYSTEM users
data:image/s3,"s3://crabby-images/64a96/64a963f04c1fcd0015993fe33b94c38977880786" alt=""
Choose the location of the binary files. Use "browse" to control location
data:image/s3,"s3://crabby-images/09108/0910847c353d3b207546ad20e457b948f49d06b7" alt=""
Let the installer finish installation
data:image/s3,"s3://crabby-images/7aaac/7aaac674009e538ee3bcbf25acc84cedef92a69e" alt=""
4. Create tablespaces for the user accounts
create tablespace doctor
datafile
'C:\ORACLEXE\APP\ORACLE\ORADATA\XE\DOCTOR01.DBF' size 500m autoextend on next
50m maxsize unlimited;
create tablespace patient
datafile
'C:\ORACLEXE\APP\ORACLE\ORADATA\XE\PATIENT01.DBF' size 500m autoextend on next
50m maxsize unlimited;
create temporary
tablespace doctortemp
tempfile 'C:\ORACLEXE\APP\ORACLE\ORADATA\XE\DOCTORTEMP01.DBF'
size 100m autoextend on next 10m maxsize unlimited;
create temporary
tablespace patienttemp
tempfile
'C:\ORACLEXE\APP\ORACLE\ORADATA\XE\PATIENTTEMP01.DBF' size 100m autoextend on
next 10m maxsize unlimited;commit;
create user doctor
identified by "oracle23678"
default tablespace doctortemporary tablespace doctortemp
quota unlimited on doctor;
create user patient
identified by "oracle23679"
default tablespace patienttemporary tablespace patienttemp
quota unlimited on patient;
commit;
grant create session
to patient;
grant create any
table to patient;grant create any sequence to patient;
grant create any procedure to patient;
grant create any synonym to patient;
grant create any index to patient;
grant create any trigger to patient;
grant create session
to doctor;
grant create any
table to doctor;grant create any sequence to doctor;
grant create any procedure to doctor;
grant create any synonym to doctor;
grant create any index to doctor;
grant create any trigger to doctor;
commit;
As SYS, run this command:
alter system set SEC_CASE_SENSITIVE_LOGON = FALSE;
commit;
Import schema into Oracle 11g XE by using the import command.
imp system/*****
file=patient.dmp fromuser=patient touser=patient
imp system/*****
file=doctor.dmp fromuser=doctor touser=doctor
Thanks for reading.
Nice post, Thanks for sharing Get more update at
ReplyDeleteOracle SOA Online Training Bangalore
"The application tracks patient information for a government agency". What government agency allows to store sensitive data in a database software that doesn't receive any patches and security fixes?
ReplyDeleteNightmare!