Home » RDBMS Server » Server Administration » user management (10.2.0.3,OEL )
user management [message #509364] Fri, 27 May 2011 06:35 Go to next message
venkatgargeyagmailcom
Messages: 20
Registered: October 2010
Location: hyderabad
Junior Member

hi,

i have a tablespace which contains 121 datafile(max limit reached)

as a dba what we have to do?

creating a new tablespace with a datafile and assign the users to the current tablespace which i created now.is this a correct solution?

if the above process is correct,after some time the tablespace which was filled up got freed up.now can i give the access to the users previous (i.e. freed up tablespace) and current tablespaces
Re: user management [message #509367 is a reply to message #509364] Fri, 27 May 2011 06:51 Go to previous messageGo to next message
ramoradba
Messages: 2457
Registered: January 2009
Location: AndhraPradesh,Hyderabad,I...
Senior Member
Quote:
121 datafile(max limit reached)

Really !
How did you come to know that this is the maximum ?
Then we will give you/Share some points.what do you say ?

Sriram
Re: user management [message #509368 is a reply to message #509364] Fri, 27 May 2011 06:53 Go to previous messageGo to next message
Mahesh Rajendran
Messages: 10708
Registered: March 2002
Location: oracleDocoVille
Senior Member
Account Moderator
>>i have a tablespace which contains 121 datafile(max limit reached)
Are you talking about ORA-1118?

If so, this is database wide limitation and just with a specific tablespace.
Backup controlfile to trace, edit the value and recreate the controlfile.
Re: user management [message #509372 is a reply to message #509367] Fri, 27 May 2011 07:02 Go to previous messageGo to next message
venkatgargeyagmailcom
Messages: 20
Registered: October 2010
Location: hyderabad
Junior Member

if u take the trace of the controlfile in that trace file u will find the max datafiles that db can have.in 10g a tablespace can have a max of 121 datafile by default


the above situation which was asked by interviewer i said the above answer.i am checking is that correct or not?

[Updated on: Fri, 27 May 2011 07:04]

Report message to a moderator

Re: user management [message #509374 is a reply to message #509372] Fri, 27 May 2011 07:05 Go to previous messageGo to next message
venkatgargeyagmailcom
Messages: 20
Registered: October 2010
Location: hyderabad
Junior Member

thanks for reply
i checked the no of datafiles in my db.they are 30.

Re: user management [message #509375 is a reply to message #509368] Fri, 27 May 2011 07:06 Go to previous messageGo to next message
ramoradba
Messages: 2457
Registered: January 2009
Location: AndhraPradesh,Hyderabad,I...
Senior Member
I doubt it !
@ op Could you please post your Output!
select value from v$parameter where name = 'db_files'
select records_total from v$controlfile_record_section where type = 'DATAFILE'

oops I am Late here

@OP http://laurentschneider.com/?s=maxdatafiles

http://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:83612348058

Quote:
the above situation which was asked by interviewer i said the above answer.i am checking is that correct or not?


It would be better to practice on your own rather than asking which will you more experience.

Sriram

[Updated on: Fri, 27 May 2011 07:26] by Moderator

Report message to a moderator

Re: user management [message #509381 is a reply to message #509375] Fri, 27 May 2011 07:20 Go to previous messageGo to next message
venkatgargeyagmailcom
Messages: 20
Registered: October 2010
Location: hyderabad
Junior Member

you find how many datafile you can have as

trace the controlfile

open the trace file you find as

create controlfile resue database "PROD" noresetlogs archivelog
maxlogfiles 16
maxlogmembers 16
maxdatafiles 30

.........................etc

[Updated on: Fri, 27 May 2011 07:21]

Report message to a moderator

Re: user management [message #509382 is a reply to message #509381] Fri, 27 May 2011 07:25 Go to previous messageGo to next message
ramoradba
Messages: 2457
Registered: January 2009
Location: AndhraPradesh,Hyderabad,I...
Senior Member
Enjoy.... Its Your Wish!.

Have you read the above links.?

Sriram
Re: user management [message #509383 is a reply to message #509372] Fri, 27 May 2011 07:27 Go to previous messageGo to next message
John Watson
Messages: 8962
Registered: January 2010
Location: Global Village
Senior Member
Hi - I think your interviewer was not testing what you think he was testing: he was testing whether you know that there is no such limit as 121 datafiles per tablespace. The limit is in fact over a thousand.
Mahesh - the controlfile setting for MAXDATAFILES is no longer meaningful. If you test it (I last tested it in 10.1, I think), you'll find that you can create as many datafiles as you want, up to the db_files parameter limit, when you get an ora-59.

Re: user management [message #509388 is a reply to message #509383] Fri, 27 May 2011 07:34 Go to previous message
ramoradba
Messages: 2457
Registered: January 2009
Location: AndhraPradesh,Hyderabad,I...
Senior Member
Thank god finally ....
Hope at-least Now OP will read the links.
C:\Windows\System32>sqlplus system/tejajun20

SQL*Plus: Release 11.2.0.1.0 Production on Fri May 27 20:20:19 2011

Copyright (c) 1982, 2010, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> select value from v$parameter where name = 'db_files';

VALUE
--------------------------------------------------------------------------------
10

SQL> select records_total from v$controlfile_record_section where type = 'DATAFILE';

RECORDS_TOTAL
-------------
          100

SQL> select file_name from dba_data_files;

FILE_NAME
--------------------------------------------------------------------------------
D:\APP1\SRIRAM\ORADATA\ORAFAQ\USERS01.DBF
D:\APP1\SRIRAM\ORADATA\ORAFAQ\UNDOTBS01.DBF
D:\APP1\SRIRAM\ORADATA\ORAFAQ\SYSAUX01.DBF
D:\APP1\SRIRAM\ORADATA\ORAFAQ\SYSTEM01.DBF
D:\APP1\SRIRAM\ORADATA\ORAFAQ\EXAMPLE01.DBF

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User2.dbf' size 100m ;

Tablespace altered.

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User3.dbf' size 100m ;

Tablespace altered.

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User4.dbf' size 100m ;

Tablespace altered.

SQL> select count(*) from v$datafile;

  COUNT(*)
----------
         8

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User5.dbf' size 100m ;

Tablespace altered.

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User6.dbf' size 100m ;

Tablespace altered.

SQL> select count(*) from v$datafile;

  COUNT(*)
----------
        10

SQL> select value from v$parameter where name = 'db_files';

VALUE
--------------------------------------------------------------------------------
10

SQL> select records_total from v$controlfile_record_section where type = 'DATAFILE';

RECORDS_TOTAL
-------------
          100

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User7.dbf' size 100m ;
alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User7.dbf' size 100m
*
ERROR at line 1:
ORA-00059: maximum number of DB_FILES exceeded



SQL> alter system set db_files=20 scope=spfile;

System altered.

SQL> conn sys as sysdba
Enter password:
Connected.
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.

Total System Global Area  401743872 bytes
Fixed Size                  1374892 bytes
Variable Size             268436820 bytes
Database Buffers          125829120 bytes
Redo Buffers                6103040 bytes
Database mounted.
Database opened.
SQL> select value from v$parameter where name = 'db_files';

VALUE
--------------------------------------------------------------------------------
20

SQL> select records_total from v$controlfile_record_section where type = 'DATAFILE';

RECORDS_TOTAL
-------------
          100

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User7.dbf' size 100m ;

Tablespace altered.

SQL>


SQL> alter system set db_files=150 scope=spfile;

System altered.

SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.

Total System Global Area  401743872 bytes
Fixed Size                  1374892 bytes
Variable Size             268436820 bytes
Database Buffers          125829120 bytes
Redo Buffers                6103040 bytes
Database mounted.
Database opened.
SQL> select value from v$parameter where name = 'db_files';

VALUE
--------------------------------------------------------------------------------
150

SQL> select records_total from v$controlfile_record_section where type = 'DATAFILE';

RECORDS_TOTAL
-------------
          100

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User8.dbf' size 1m ;

Tablespace altered.

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User9.dbf' size 1m ;

Tablespace altered.

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User10.dbf' size 1m ;

Tablespace altered.


SQL> select count(*) from v$datafile;

  COUNT(*)
----------
        14
--- In another window I am adding datafiles upto the limit "100"
SQL> /

  COUNT(*)
----------
        48

SQL> /

  COUNT(*)
----------
        55

SQL> /

  COUNT(*)
----------
        82

SQL> /

  COUNT(*)
----------
        98

SQL> /

  COUNT(*)
----------
        98

SQL> /

  COUNT(*)
----------
        98

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User95.dbf' size 1m ;

Tablespace altered.

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User96.dbf' size 1m ;

Tablespace altered.

SQL>
SQL> select value from v$parameter where name = 'db_files';

VALUE
--------------------------------------------------------------------------------
150

SQL> select records_total from v$controlfile_record_section where type = 'DATAFILE';

RECORDS_TOTAL
-------------
          100

SQL> alter tablespace users add datafile 'D:\APP1\SRIRAM\ORADATA\ORAFAQ\User97.dbf' size 1m ;

Tablespace altered.

SQL> select value from v$parameter where name = 'db_files';

VALUE
--------------------------------------------------------------------------------
150

SQL> select records_total from v$controlfile_record_section where type = 'DATAFILE';

RECORDS_TOTAL
-------------
          200

----Observe it Automatically changed..

SQL>



http://download.oracle.com/docs/cd/B19306_01/server.102/b14237/initparams049.htm#REFRN10039

http://download.oracle.com/docs/cd/B19306_01/server.102/b14231/dfiles.htm#sthref1343


Quote:
Consider Possible Limitations When Adding Datafiles to a Tablespace

You can add datafiles to traditional smallfile tablespaces, subject to the following limitations:

Operating systems often impose a limit on the number of files a process can open simultaneously. More datafiles cannot be created when the operating system limit of open files is reached.

Operating systems impose limits on the number and size of datafiles.

The database imposes a maximum limit on the number of datafiles for any Oracle Database opened by any instance. This limit is operating system specific.

You cannot exceed the number of datafiles specified by the DB_FILES initialization parameter.

When you issue CREATE DATABASE or CREATE CONTROLFILE statements, the MAXDATAFILES parameter specifies an initial size of the datafile portion of the control file. However, if you attempt to add a new file whose number is greater than MAXDATAFILES, but less than or equal to DB_FILES, the control file will expand automatically so that the datafiles section can accommodate more files.
Quote:
DB_FILES specifies the maximum number of database files that can be opened for this database.
The maximum valid value is the maximum number of files, subject to operating system constraint,
that will ever be specified for the database, including files to be added by ADD DATAFILE statements.
If you increase the value of DB_FILES, then you must shut down and restart all instances
accessing the database before the new value can take effect. If you have a primary and standby database,
then they should have the same value for this parameter.





Sriram Smile

[Updated on: Fri, 27 May 2011 11:43]

Report message to a moderator

Previous Topic: ORA-01034 while running dbca (5 threads merged by bb)
Next Topic: Database Shutdown
Goto Forum:
  


Current Time: Sun Jan 12 16:35:07 CST 2025