Available with Standard or Advanced license.
To create a geodatabase in an Oracle database, run a geoprocessing tool or Python script from an ArcGIS client.
When you create a geodatabase from ArcGIS AllSource 3.5, the geodatabase version is 11.5.0.x.
Start by reading the prerequisites, and follow the instructions that apply to your situation.
Note:
Creating or upgrading user-schema geodatabases in Oracle is no longer supported.
Prerequisites
Before you create a geodatabase in Oracle, do the following:
- Confirm that the ArcGIS, Oracle, and operating system combinations you want to use are compatible.
- Obtain the Oracle client required to connect to the version of Oracle you'll use to store your geodatabase.
- Obtain an ArcGIS Server keycodes file—which is created when you authorize ArcGIS Server—and place it in a location you can access from the ArcGIS client you'll use to create the geodatabase.
- Determine who will create the geodatabase, as that affects which tool you run to create the geodatabase. Follow the instructions that apply to your situation.- If you are the database administrator and the geodatabase administrator, follow the instructions in the next section.
- If the database administrator and geodatabase administrator are two different people, follow the instructions for the Oracle administrator to configure the database and the geodatabase administrator to create the geodatabase
 
You are the database and geodatabase administrator
If you perform the role of both the database administrator and geodatabase administrator and, therefore, know the password for both logins, you can use the Create Enterprise Geodatabase geoprocessing tool, or a Python script that calls this tool, to create a geodatabase in Oracle.
The Create Enterprise Geodatabase tool creates the sde user, schema, and tablespace, and grants privileges to the sde user that are required to create the geodatabase. To achieve this, the tool uses the following default settings:
- Creates a database user named sde
- Creates a 400 MB tablespace in the Oracle default location and sets it as the sde user's tablespace
- Grants the sde user privileges to create and upgrade a geodatabase, remove database connections, and import data using Oracle Data Pump
- Grants package privileges required to create a geodatabase
- Creates a geodatabase
For more information on required privileges, see Privileges for geodatabases in Oracle.
Note:
You cannot use this workflow to create a geodatabase in a database service.
Before you run the tool or script to create a geodatabase, you must set up Oracle.
Install and configure Oracle
Before you create a geodatabase, Oracle must be installed and configured. How you (or your IT department) configure the Oracle instance depends on the specific needs of your organization. Consult the Oracle documentation for installation and configuration information.
Check the ArcGIS system requirements for Oracle before you create a geodatabase to be sure the Oracle, ArcGIS, and hardware combinations you want to use are supported.
If you require the ability to do any of the following, you also need to configure the Oracle extproc to access the Esri ST_Geometry libraries:
- Run ST_Geometry SQL functions from SQL clients.
- Define a query layer that runs SQL functions on ST_Geometry columns.
- Query binned feature layers in ArcGIS AllSource.
- Publish a web layer that references data in the Oracle database.
- Run the Select Layer By Location geoprocessing tool with the Intersect (DBMS) option.
After Oracle is installed and configured, install ArcGIS and Oracle clients.
Install and configure clients
You can install ArcGIS AllSource (Desktop Standard or Desktop Advanced) or ArcGIS Server (enterprise edition) and run a script to create a geodatabase. To run the Create Enterprise Geodatabase geoprocessing tool instead of a script, install ArcGIS AllSource.
Note:
You need an ArcGIS Server (enterprise) keycodes file to authorize your geodatabase in the next section. Even if you do not run a Python script from an ArcGIS Server machine to create the geodatabase, you must install and authorize ArcGIS Server to get the keycodes file. You may need to copy the file from the ArcGIS Server machine to a location the geoprocessing tool or Python script can access.
In most cases, your ArcGIS client will be installed on a different computer than Oracle. Therefore, you must have a supported Oracle client on the ArcGIS client computer to connect to the Oracle instance. See the Oracle documentation to determine which version of the Oracle client you must install to connect to the version of Oracle you are using and for instructions to install and configure the Oracle client.
- Install the ArcGIS client you'll use to create the geodatabase.Follow the instructions provided in the software installation guides. 
- Install and configure an Oracle client on the ArcGIS client computer.You can obtain the Oracle Instant, Runtime, or Administrator Client from Oracle. See the Oracle documentation for instructions to install. 
- Set the environment variable of your operating system or user profile to include the path to and name of the directory where the Oracle client is installed.- On Linux, set the LD_LIBRARY_PATH environment variable.
- On Microsoft Windows, set the PATH environment variable.
 
- If the ArcGIS client was already running, restart it to recognize the Oracle client and new environment variables.
- You can connect from ArcGIS to Oracle using an Easy Connect string, but you must configure your Oracle database to allow Easy Connect strings.If you have the full Oracle client installed but want to use Easy Connect syntax to connect, be sure the sqlnet.ora file on the client is configured to allow the use of Easy Connect and the Oracle server is configured to allow Easy Connect syntax. See the Oracle documentation for further instructions. 
Now you can create a geodatabase.
Create a geodatabase
You can run the Create Enterprise Geodatabase tool from ArcGIS AllSource (Desktop Standard or Desktop Advanced), or run a Python script from ArcGIS AllSource or an ArcGIS Server machine to create an sde user, schema, tablespace, and geodatabase.
Run the Create Enterprise Geodatabase tool
You can run a geoprocessing tool to create the geodatabase in ArcGIS AllSource.
Follow these steps to create a geodatabase using the Create Enterprise Geodatabase tool:
- Start ArcGIS AllSource.
- Open the Create Enterprise Geodatabase tool.You can search for or browse to this tool, which is located in the Geodatabase Administration toolset of the Data Management toolbox. See Find a geoprocessing tool for general information about opening geoprocessing tools. 
- Choose Oracle from the Database Platform drop-down list.
- Provide the information required to connect to the Oracle instance.- If you already configured the Oracle client to use a TNS network alias, type the Net service alias in the Instance text box.
- If you have not configured the Oracle client's network alias and your Oracle database and client are configured to use Easy Connect strings, provide the Oracle Easy Connect string in the Instance text box.
 See Connect to Oracle from ArcGIS for a list of possible Easy Connect strings. 
- Type the sys user's password in the Database Administrator Password text box.
- Type sde in the Geodatabase Administrator text box.If the sde user does not exist in the database, the tool creates it and grants it the privileges necessary to create a geodatabase. If the user exists, the required privileges are granted to it. 
- Type a password for the sde user in the Geodatabase Administrator Password text box.If the sde user already exists in the database, you must type the correct password for the existing user; this tool will not change the password. If you are creating an sde user, the password you type is used when creating the sde user. 
- Specify a tablespace for the sde user.- If you have a preconfigured tablespace to be used for the geodatabase repository, type its name in the Tablespace Name text box.
- To create a tablespace, type a valid name in the Tablespace Name text box and the tool creates a 400 MB tablespace in the Oracle default location. If you do not type a tablespace name, SDE_TBS tablespace is created and set as the default tablespace for the sde user.
 
- To specify an Authorization File, browse to and choose the keycodes file that was created when you authorized ArcGIS Server.If you have not already done so, authorize ArcGIS Server now to create the keycodes file. This file is written to the \\Program Files\ESRI\License<release#>\sysgen folder on Windows servers and /arcgis/server/framework/runtime/.wine/drive_c/Program Files/ESRI/License<release#>/sysgen on Linux servers. Copy the keycodes file to a location the tool can access. 
- Click Run.Messages about geodatabase creation are written to the sde_setup.log file, which is created in the directory specified for your %TEMP% variable on the computer where the tool is run. If you have any problems creating a geodatabase, review this log file to troubleshoot the problem. 
A geodatabase is created in the Oracle database.
Next, if the Oracle database open_cursors parameter is set to anything other than 300, run the sde.gdb_util.update_open_cursors stored procedure to synchronize your Oracle database parameter with the geodatabase's setting.
Run a Python script
You can copy, save, and run the script provided here to create a geodatabase from ArcGIS AllSource (Desktop Standard or Desktop Advanced) or an ArcGIS Server machine.
- Create a text file on the ArcGIS client machine and copy the following script into the file, providing information specific to your site:""" Name: create_enterprise_gdb.py Description: Create an enterprise geodatabase in Oracle with provided DBMS connection information Author: Esri """ # Import system modules import arcpy, os # Local variables # Provide correct path to your keycodes file # Replace all arcpy.management.CreateEnterpriseGeodatabase values except "ORACLE", "sys", "sde", and license license = os.fsencode("/arcgis/path/to/authorization_file/keycodes") try: arcpy.management.CreateEnterpriseGeodatabase("ORACLE", "oracle:1521/orainstance", "", "DATABASE_AUTH", "sys", "syspwdqF2b3pxJp3j2", "", "sde", "sdepwdkzsPzL8GuCEA", "sdetblspace", license) for i in range(arcpy.GetMessageCount()): arcpy.AddReturnMessage(i) arcpy.AddMessage("+++++++++\n") except: for i in range(arcpy.GetMessageCount()): arcpy.AddReturnMessage(i)
- Replace values as noted in the script.
- Save the file with a .py extension.
- Run the script.Messages about geodatabase creation are written to the sde_setup.log file, which is created in the directory specified for your TEMP or TMP variable on the computer where the script is run. If you have any problems creating a geodatabase, review this log file to troubleshoot the problem. 
You now have a geodatabase in Oracle.
Next, if the Oracle database open_cursors parameter is set to anything other than 300, run the sde.gdb_util.update_open_cursors stored procedure to synchronize your Oracle database parameter with the geodatabase's setting.
The Oracle administrator configures the database; the geodatabase administrator creates the geodatabase
If the person creating the geodatabase does not have access to the database administrator's password, the database administrator can set up the database and sde user, and then the geodatabase administrator can connect to the database using the sde login and create a geodatabase using the Enable Enterprise Geodatabase geoprocessing tool or a Python script.
The Enable Enterprise Geodatabase tool takes a database connection file as input and creates the geodatabase system tables, views, functions, and procedures in the sde user's schema.
Install and configure Oracle
Before the geodatabase administrator can create a geodatabase, the database administrator must do the following:
- Install and configure an Oracle instance. How you configure the Oracle instance depends on the specific needs of your organization. Consult Oracle documentation for installation and configuration information.Check the ArcGIS system requirements to ensure the database management system, ArcGIS, and hardware combinations you want to use are supported. 
- Create an sde user and schema.
- Grant the sde user the privileges necessary to create a geodatabase. See Privileges for geodatabases in Oracle for a list of required privileges.
- Create a tablespace for the sde user and set the tablespace as the sde user's default tablespace.
- Grant execute privileges on packages needed for geodatabase creation. See Privileges for geodatabases in Oracle for a list of the packages.
If you require the ability to do any of the following, you must also configure the Oracle extproc to access the Esri ST_Geometry libraries:
- Run ST_Geometry SQL functions from SQL clients.
- Define a query layer that runs SQL functions on ST_Geometry columns.
- Query binned feature layers in ArcGIS AllSource.
- Publish a web layer that references data in the Oracle database.
- Run the Select Layer By Location geoprocessing tool with the Intersect (DBMS) option.
After Oracle is installed and configured, the geodatabase administrator can install ArcGIS and Oracle clients.
Install and configure clients
You can install ArcGIS AllSource (Desktop Standard or Desktop Advanced) or ArcGIS Server to run a Python script and create a geodatabase. If you want to run the Enable Enterprise Geodatabase geoprocessing tool instead of a script, install ArcGIS AllSource.
Note:
You need an ArcGIS Server (enterprise) keycodes file to authorize your geodatabase in the next section. Even if you do not run a Python script from an ArcGIS Server machine to create the geodatabase, you must install and authorize ArcGIS Server to get the keycodes file. You may need to copy the file from the ArcGIS Server machine to a location the geoprocessing tool or Python script can access.
In most cases, your ArcGIS client will be installed on a different computer than Oracle. Therefore, you must have a supported Oracle client on the ArcGIS client computer to connect to the Oracle instance. See Oracle documentation to determine which version of the Oracle client you should install to connect to the version of Oracle you are using and for instructions on installing and configuring the client.
- Install the ArcGIS client you'll use to create the geodatabase.Follow the instructions provided in the software installation guides. 
- Install and configure an Oracle client on the ArcGIS client computer.You can obtain the Oracle Instant, Runtime, or Administrator Client from Oracle. See the Oracle documentation for instructions to install. 
- Set the environment variable of your operating system or user profile to include the path to and name of the directory where the Oracle client is installed.- On Linux, set the LD_LIBRARY_PATH environment variable.
- On Windows, set the PATH environment variable.
 
- If the ArcGIS client was already running, restart it to recognize the Oracle client and new environment variables.
Now you can create a geodatabase.
Create a geodatabase
The geodatabase administrator can run the Enable Enterprise Geodatabase tool from ArcGIS AllSource (Desktop Standard or Desktop Advanced), or run a Python script from an ArcGIS AllSource (Desktop Standard or Desktop Advanced) or ArcGIS Server machine to create a geodatabase in the existing database.
Run the Enable Enterprise Geodatabase ArcGIS Desktop tool
Run the geoprocessing tool from ArcGIS AllSource to create a geodatabase.
Follow these steps to create a geodatabase using the Enable Enterprise Geodatabase geoprocessing tool:
- Start ArcGIS AllSource.
- Connect to the Oracle database as the sde user.Save the user's password on the Database Connection dialog box. 
- Open the Enable Enterprise Geodatabase geoprocessing tool.See Find a geoprocessing tool for general information about opening geoprocessing tools. 
- Use the database connection you created in step 2 for Input Database Connection.
- Browse to the authorization file that was created when you authorized ArcGIS Server and add it to the Authorization File text box.If you have not already done so, authorize ArcGIS Server to create this file. When you use the wizard to authorize ArcGIS Server, a keycodes file is written to the server where the software is installed. If you authorized ArcGIS Server on a Linux machine, the keycodes file was created in /arcgis/server/framework/runtime/.wine/drive_c/Program Files/ESRI/License<release>/sysgen. If you authorized on a Windows server, the file was created in Program Files\ESRI\License<release>\sysgen. Copy the keycodes file to a location the tool can access. 
- Click Run.Messages about geodatabase creation are written to the sde_setup.log file, which is created in the directory specified for your %TEMP% variable on the computer where the tool is run. If you have any problems creating a geodatabase, review this log file to troubleshoot the problem. 
A geodatabase is created in the database.
If clients will access the geodatabase using SQL, configure the Oracle extproc to allow access.
Next, the database administrator can synchronize open_cursors settings between Oracle and the geodatabase using the sde.gdb_util.update_open_cursors stored procedure.
Run a Python script
If you want to create the geodatabase by running a script from an ArcGIS Server or ArcGIS AllSource installation, you can use the script provided here.
- Create a text file on the ArcGIS client machine and copy the following script into the file, providing information specific to your site:# Name: enable_enterprise_gdb.py # Description: Create an enterprise geodatabase in an existing Oracle database # Import system modules import arcpy, os # Local variables # Replace directories to work for your site license = "/arcgis/path/to/authorization_file/keycodes" tempdir = "/tmp/" connection_file_name = "egdb_connection.sde" # Check for the .sde file and delete it if present connection_file_name_path = os.path.join(tempdir, connection_file_name) arcpy.env.overwriteOutput=True if os.path.exists(connection_file_name_path): os.remove(connection_file_name_path) # Create a connection to the geodatabase as the geodatabase administrator # Replace "gisprod/orcl" with your Oracle instance string and replace "Tgdbst@rtsh3r3" with your sde password arcpy.CreateDatabaseConnection_management(tempdir, connection_file_name, "ORACLE", "gisprod/orcl", "DATABASE_AUTH", "sde", "Tgdbst@rtsh3r3", "SAVE_USERNAME") # Enable geodatabase try: arcpy.EnableEnterpriseGeodatabase_management(connection_file_name_path, license) except: for i in range(arcpy.GetMessageCount()): arcpy.AddReturnMessage(i)
- Replace values as noted in the script.
- Save the file with a .py extension.
- Run the script.Messages about geodatabase creation are written to the sde_setup.log file, which is created in the directory specified for your TEMP or TMP variable on the computer where the script is run. If you have any problems creating a geodatabase, review this log file to troubleshoot the problem. 
You now have a geodatabase in the Oracle database.
Next, the database administrator can synchronize open_cursors settings between Oracle and the geodatabase using the sde.gdb_util.update_open_cursors stored procedure.