Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Oracle Max ID in Tables

Posted on 2016-09-27
10
Medium Priority
?
89 Views
Last Modified: 2016-09-28
Is there a way in PSQL to look at the tables  in (PROD1) and see...

The Maximum possible ID for that table (Or set of tables)
And the current MAX(ID) in that table(s)

This is an old Oracle Database
I have access to TOAD 10.5.1.3
0
Comment
Question by:lrbrister
  • 3
  • 3
  • 2
  • +2
10 Comments
 
LVL 35

Expert Comment

by:Pawan Kumar
ID: 41819050
You can use below.

SELECT MAX(ID) MaxId FROM TableName

Open in new window


The maximum possible Id depends on the datatype you have used for Id column.

As per Oracle documentation below are the minimum and the maximum value we can store for numeric data types in Oracle.

INTEGER

A whole number in the range of (-2**31) to (2**31)-1.

SHORTINTEGER

A whole number in the range of (-2**15) to (2**15)-1.

LONGINTEGER

A whole number in the range of (-2**63) to (2**63)-1.

DECIMAL

A decimal number with up to 15 significant digits in the range of -(10**308) to +(10**308).

SHORTDECIMAL

A decimal number with up to 7 significant digits in the range of -(10**38) to +(10**38).

NUMBER

A decimal number with up to 38 significant digits in the range of -(10**125) to +(10**125).
0
 
LVL 78

Expert Comment

by:slightwv (䄆 Netminder)
ID: 41819051
Maximum possible is likely based on the data type and the maximum value it can hold.

If generated by a sequence, then it is the maximum value allowed by the sequence.

If you have a list of tables, then the above comments apply to the entire list.

'old Oracle Database' doesn't mean anything.  What version?  Please include all 4 numbers, or example 10.2.0.4.

All that said, can explain just a little more about exactly what you are trying to do?
0
 

Author Comment

by:lrbrister
ID: 41819068
Two tables id's reached the "set " maximum allowed number

And inserts stopped

I want to know the current max ID

And the maximum allowed "ceiling" ID on the table
0
Free Backup Tool for VMware and Hyper-V

Restore full virtual machine or individual guest files from 19 common file systems directly from the backup file. Schedule VM backups with PowerShell scripts. Set desired time, lean back and let the script to notify you via email upon completion.  

 
LVL 35

Expert Comment

by:Pawan Kumar
ID: 41819072
In this case you need to alter the datatype to the higher datatype.

Do take backup of the existing table and then try.

Alter Table table_name 
modify (  column_name LONG );

Open in new window

0
 
LVL 78

Accepted Solution

by:
slightwv (䄆 Netminder) earned 2000 total points
ID: 41819074
Sorry but that doesn't tell me anything.

If you are getting some error message, please provide it.

For example, if you have a sequence called MYSEQ and exceed it's value then you should get:
ORA-08004: sequence MYSEQ.NEXTVAL exceeds MAXVALUE and cannot be instantiated

To get the max value for it:
select max_value from user_sequences where sequence_name='MYSEQ';

If you mean something different, please provide more details.
0
 
LVL 78

Expert Comment

by:slightwv (䄆 Netminder)
ID: 41819075
>>modify (  column_name LONG );

NO.  Do not use a LONG data type.  They are a nightmare to work with.
0
 

Author Closing Comment

by:lrbrister
ID: 41819076
That gave me exactly what I needed
0
 
LVL 35

Expert Comment

by:Pawan Kumar
ID: 41819077
Yes changing datatype is bit difficult.

But sometimes we have to do it.  You can use datatype based on your requirement.
0
 
LVL 38

Expert Comment

by:Geert Gruwez
ID: 41819203
Pawan,
really ? suggesting a long data type ?

Read the post upgrade tasks in the upgrade guide.
http://docs.oracle.com/database/121/UPGRD/afterup.htm#UPGRD12441
0
 
LVL 35

Expert Comment

by:johnsone
ID: 41819600
Why would you recommend changing the data type from a numeric type to a character type?  That makes absolutely no sense at all.  Not only is it not a numeric type, but it is no longer a supported data type and hasn't been since 9i.  It hasn't even been in the documentation for quite a few versions.

Also, I am curious where you get the documentation reference for these types:

SHORTINTEGER
LONGINTEGER
SHORTDECIMAL

They aren't in the documentation and will generate an error if you try to use them.  INTEGER and DECIMAL just get translated to NUMBER(38).
0

Featured Post

Nothing ever in the clear!

This technical paper will help you implement VMware’s VM encryption as well as implement Veeam encryption which together will achieve the nothing ever in the clear goal. If a bad guy steals VMs, backups or traffic they get nothing.

Question has a verified solution.

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

Your data is at risk. Probably more today that at any other time in history. There are simply more people with more access to the Web with bad intentions.
This article shows how to get a list of available printers for display in a drop-down list, and then to use the selected printer to print an Access report or a Word document filled with Access data, using different syntax as needed for working with …
Video by: Steve
Using examples as well as descriptions, step through each of the common simple join types, explaining differences in syntax, differences in expected outputs and showing how the queries run along with the actual outputs based upon a simple set of dem…
In this video, Percona Solution Engineer Dimitri Vanoverbeke discusses why you want to use at least three nodes in a database cluster. To discuss how Percona Consulting can help with your design and architecture needs for your database and infras…

824 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