public class EmbeddedDataSource extends org.apache.derby.jdbc.ReferenceableDataSource implements Referenceable
This data source is suitable for an application using embedded Derby, running on full Java SE 6 and higher, corresponding to 4.0 and higher.
A DataSource is a factory for Connection objects. An object that implements the DataSource interface will typically be registered with a JNDI service provider.
EmbeddedDataSource automatically supports the correct JDBC specification version for the Java Virtual Machine's environment.
Use BasicEmbeddedDataSource40 if your application runs on Java 8 Compact Profile 2.
The following is a list of properties that can be set on a Derby DataSource object:
Standard DataSource properties (from JDBC 3.0 specification).
databaseName (String): Mandatory
        setDatabaseName("g:/db/wombat") on the data source object.dataSourceName (String): Optional
        description (String): Optional
        password (String): Optional
        DataSource.getConnection(),
        ConnectionPoolDataSource.getPooledConnection()
        and XADataSource.getXAConnection() methods.
        user (String): Optional
        DataSource.getConnection(),
        ConnectionPoolDataSource.getPooledConnection()
        and XADataSource.getXAConnection() methods.
        attributesAsPassword (Boolean): Optional
        DataSource.getConnection(String user, String password),
        ConnectionPoolDataSource.getPooledConnection(String user, String password)
        or XADataSource.getXAConnection(String user, String password) as a set
        of connection attributes. The format of the attributes is the same as the format
        of the attributes in the property connectionAttributes. If false the password value
        is treated normally as the password for the given user.
        Setting this property to true allows a connection request from an application to
        provide more authentication information that just a password, for example the request
        can include the user's password and an encrypted database's boot password.connectionAttributes (String): Optional
  attribute=value, each separated by semi-colon (';').
  E.g. setConnectionAttributes("bootPassword=erd3234dggd3kazkj3000");.
  databaseName and not by setting the databaseName
  connection attribute in the connectionAttributes property.
        createDatabase (String): Optional
        databaseName if that database does not already
        exist.  The database is created when a connection object is obtained from
        the data source. shutdownDatabase (String): Optional
        Examples.
This is an example of setting a property directly using Derby's EmbeddedDataSource object. This code is typically written by a system integrator :
 
 import org.apache.derby.jdbc.*;
 // dbname is the database name
 // if create is true, create the database if necessary
 javax.sql.DataSource makeDataSource (String dbname, boolean create)
        throws Throwable 
 { 
        EmbeddedDataSource ds = new EmbeddedDataSource(); 
        ds.setDatabaseName(dbname);
        if (create)
                ds.setCreateDatabase("create");
   
        return ds;
 }
        
        Example of setting properties thru reflection. This code is typically generated by tools or written by a system integrator:
        
 javax.sql.DataSource makeDataSource(String dbname) 
        throws Throwable 
 {
        Class[] parameter = new Class[1];
        parameter[0] = dbname.getClass();
        DataSource ds =  new EmbeddedDataSource();
        Class cl = ds.getClass();
        Method setName = cl.getMethod("setDatabaseName", parameter);
        Object[] arg = new Object[1];
        arg[0] = dbname;
        setName.invoke(ds, arg);
        return ds;
 }
        
        Example on how to register a data source object with a JNDI naming service.
 DataSource ds = makeDataSource("mydb");
 Context ctx = new InitialContext();
 ctx.bind("jdbc/MyDB", ds);
        
        Example on how to retrieve a data source object from a JNDI naming service.
 Context ctx = new InitialContext();
 DataSource ds = (DataSource)ctx.lookup("jdbc/MyDB");
        | Constructor and Description | 
|---|
| EmbeddedDataSource()No-arg constructor. | 
| Modifier and Type | Method and Description | 
|---|---|
| Object | getObjectInstance(Object refObj,
                 Name name,
                 Context nameContext,
                 Hashtable<?,?> environment)Reconstructs a Derby embedded-driver data source object from a JNDI data
 source reference. | 
| Reference | getReference()This method creates a new  Referenceobject to represent this
 data source. | 
equals, getAttributesAsPassword, getConnection, getConnection, getConnectionAttributes, getCreateDatabase, getDatabaseName, getDataSourceName, getDescription, getLoginTimeout, getLogWriter, getParentLogger, getPassword, getShutdownDatabase, getUser, hashCode, isWrapperFor, setAttributesAsPassword, setConnectionAttributes, setCreateDatabase, setDatabaseName, setDataSourceName, setDescription, setLoginTimeout, setLogWriter, setPassword, setShutdownDatabase, setUser, unwrappublic final Reference getReference() throws NamingException
Reference object to represent this
 data source.  The class name of the data source object is saved
 in the Reference, so that an object factory will know that it
 should create an instance of that class when a lookup operation
 is performed. The class is also stored in the reference.  This
 is not required by JNDI, but is recommend in practice.  JNDI
 will always use the object factory class specified in the
 reference when reconstructing an object, if a class name has
 been specified.  See the JNDI SPI documentation for further
 details on this topic, and for a complete description of the
 Reference and StringRefAddr classes.
 
 Derby data source classes class provides several standard JDBC
 properties.  The names and values of the data source properties
 are also stored in the reference using the StringRefAddr class.
 This is all the information needed to reconstruct an embedded
 data source object.getReference in interface ReferenceableNamingException - cannot find named objectpublic Object getObjectInstance(Object refObj, Name name, Context nameContext, Hashtable<?,?> environment) throws Exception
org.apache.derby.jdbc.ReferenceableDataSource
 The getObjectInstance method is passed a reference that
 corresponds to the object being retrieved as its first parameter. The
 other parameters are optional in the case of JDBC data source objects.
 The object factory should use the information contained in the reference
 to reconstruct the data source. If for some reason, a data source
 object cannot be reconstructed from the reference, a value of
 null may be returned. This allows other object factories that may
 be registered in JNDI to be tried. If an exception is thrown then no
 other object factories are tried.
getObjectInstance in interface ObjectFactorygetObjectInstance in class org.apache.derby.jdbc.ReferenceableDataSourcerefObj - the possibly null object containing location or
      reference information that can be used in creating an objectname - the name of this object relative to nameContext, or
      null if no name is specifiednameContext - context relative to which the name parameter is
      specified, or null if name is relative to the default
      initial context.environment - possibly null environment that is used in
      creating the object.null if no attempt to create the
      object is made.Exception - if recreating the object failsApache Derby 10.11 API Documentation - Copyright © 2004,2014 The Apache Software Foundation. All Rights Reserved.