?
Solved

Oracle Version, TOAD VI and Drop Column

Posted on 2004-10-14
11
Medium Priority
?
4,873 Views
Last Modified: 2007-12-19
Hi,

I'm trying to delete a column from an Oracle database... I know there's a SQL command to do this, but only for version 8i and newer.  So, my questions are:

1.- How can I retrieve the version of my Oracle DB using TOAD (you know, using only SQL)
2.- If my version is older than 8i, how do I drop the column

That's about it.
Thanks!

TCV
0
Comment
Question by:Taconvino
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 5
11 Comments
 
LVL 23

Expert Comment

by:seazodiac
ID: 12310025
1. that will be :

select * from v$version;


2. alter table <table_name> drop column <column_name>;

0
 
LVL 6

Author Comment

by:Taconvino
ID: 12310065
OK! Now I got the version, but when I run the Alter, I get this error message:

The following error has occurred:

ORA-00905: missing keyword

And leaves the word "column" selected.
So, I guess the command doesn't work for Oracle8 Release 8.0.4.0.0.  Please, any other help would be great!

TCV
0
 
LVL 23

Accepted Solution

by:
seazodiac earned 2000 total points
ID: 12310100
as you said, the drop column does not work for oracle8.

the workaround is to recreate :

create table <new_table_name> as
select col1, col2, ...coln          --DON'T include the column-to-be-dropped
from <table_name>;


additionally, you have to put back in all the constraints and indexes, sequences and synonyms;
0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 23

Expert Comment

by:seazodiac
ID: 12310116
There is another way:

you can create a VIEW on top of that table:

create view <new_view_name>
as
select col1, col2, ....coln --Exclude the column-to-be-dropped
from <table_name>;


and direct users to use this view instead of this table.


I like this option better, because it does not disrupt your table structure and don't need to re-create all the constraints.
0
 
LVL 6

Author Comment

by:Taconvino
ID: 12310119
So, I have to recreate the table with a new name, then drop the old table, and then rename the new table, right?  Does the rename command work for Oracle8?

TCV
0
 
LVL 23

Expert Comment

by:seazodiac
ID: 12310126
Nope
0
 
LVL 6

Author Comment

by:Taconvino
ID: 12310175
Hummm... that leaves me right in the start, right?  Any way, I can do the same process twice to get where I want.  The view could be better, under other circumstances... anyway, Thanks!

TCV
0
 
LVL 23

Expert Comment

by:seazodiac
ID: 12310199
taconvino:

Rename table actually works in Oracle8 .It's getting rusty on me...I havenot used 8 for coon's age.
0
 
LVL 6

Author Comment

by:Taconvino
ID: 12314424
You're kidding!  Can you post the correct syntax please?  Thanks!

TCV
0
 
LVL 23

Expert Comment

by:seazodiac
ID: 12314647
easy:
just

rename <table_name> to <new_table_name>;


alter table <table_name> rename to <new_table_name>;
0
 
LVL 6

Author Comment

by:Taconvino
ID: 12328625
I'll check this on monday.  Thanks again!

TCV
0

Featured Post

On Demand Webinar: Networking for the Cloud Era

Did you know SD-WANs can improve network connectivity? Check out this webinar to learn how an SD-WAN simplified, one-click tool can help you migrate and manage data in the cloud.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Cursors in Oracle: A cursor is used to process individual rows returned by database system for a query. In oracle every SQL statement executed by the oracle server has a private area. This area contains information about the SQL statement and theā€¦
Shell script to create broker configuration file using current broker Configuration, solely for purpose of backup on Linux. Script may need to be modified depending on OS-installation. Please deploy and verify the script in a test environment.
This video explains at a high level with the mandatory Oracle Memory processes are as well as touching on some of the more common optional ones.
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Suggested Courses

741 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question