Package org.h2.server.pg
Class PgServer
java.lang.Object
org.h2.server.pg.PgServer
- All Implemented Interfaces:
Service
This class implements a subset of the PostgreSQL protocol as described here:
https://www.postgresql.org/docs/devel/protocol.html
The PostgreSQL catalog is described here:
https://www.postgresql.org/docs/7.4/catalogs.html
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intThe default port to use for the PG server.static final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intThe VARCHAR type.static final int -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionIf no key is set, return the original database name.static intconvertType(TypeInfo type) Convert the SQL type to a PostgreSQL typestatic StringformatType(int pgType) Returns the name of the given type.booleanCheck if remote connections are allowed.getName()Get the human readable name of the service.intgetPort()Gets the port this service is listening on.getType()Get the human readable short name of the service.getURL()Get the URL of this service in a human readable formvoidInitialize the service from command line options.booleanisDaemon()Check if a daemon thread should be used.booleanisRunning(boolean traceError) Check if the service is running.voidlisten()Listen for incoming connections.voidstart()Start the service.voidstop()Stop the service.
-
Field Details
-
DEFAULT_PORT
public static final int DEFAULT_PORTThe default port to use for the PG server. This value is also in the documentation and in the Server javadoc.- See Also:
-
PG_TYPE_VARCHAR
public static final int PG_TYPE_VARCHARThe VARCHAR type.- See Also:
-
PG_TYPE_BOOL
public static final int PG_TYPE_BOOL- See Also:
-
PG_TYPE_BYTEA
public static final int PG_TYPE_BYTEA- See Also:
-
PG_TYPE_BPCHAR
public static final int PG_TYPE_BPCHAR- See Also:
-
PG_TYPE_INT8
public static final int PG_TYPE_INT8- See Also:
-
PG_TYPE_INT2
public static final int PG_TYPE_INT2- See Also:
-
PG_TYPE_INT4
public static final int PG_TYPE_INT4- See Also:
-
PG_TYPE_TEXT
public static final int PG_TYPE_TEXT- See Also:
-
PG_TYPE_FLOAT4
public static final int PG_TYPE_FLOAT4- See Also:
-
PG_TYPE_FLOAT8
public static final int PG_TYPE_FLOAT8- See Also:
-
PG_TYPE_UNKNOWN
public static final int PG_TYPE_UNKNOWN- See Also:
-
PG_TYPE_INT2_ARRAY
public static final int PG_TYPE_INT2_ARRAY- See Also:
-
PG_TYPE_INT4_ARRAY
public static final int PG_TYPE_INT4_ARRAY- See Also:
-
PG_TYPE_VARCHAR_ARRAY
public static final int PG_TYPE_VARCHAR_ARRAY- See Also:
-
PG_TYPE_DATE
public static final int PG_TYPE_DATE- See Also:
-
PG_TYPE_TIME
public static final int PG_TYPE_TIME- See Also:
-
PG_TYPE_TIMETZ
public static final int PG_TYPE_TIMETZ- See Also:
-
PG_TYPE_TIMESTAMP
public static final int PG_TYPE_TIMESTAMP- See Also:
-
PG_TYPE_TIMESTAMPTZ
public static final int PG_TYPE_TIMESTAMPTZ- See Also:
-
PG_TYPE_NUMERIC
public static final int PG_TYPE_NUMERIC- See Also:
-
-
Constructor Details
-
PgServer
public PgServer()
-
-
Method Details
-
init
Description copied from interface:ServiceInitialize the service from command line options. -
getURL
Description copied from interface:ServiceGet the URL of this service in a human readable form -
getPort
public int getPort()Description copied from interface:ServiceGets the port this service is listening on. -
start
public void start()Description copied from interface:ServiceStart the service. This usually means create the server socket. This method must not block. -
listen
public void listen()Description copied from interface:ServiceListen for incoming connections. This method blocks. -
stop
public void stop()Description copied from interface:ServiceStop the service. -
isRunning
public boolean isRunning(boolean traceError) Description copied from interface:ServiceCheck if the service is running. -
getAllowOthers
public boolean getAllowOthers()Description copied from interface:ServiceCheck if remote connections are allowed.- Specified by:
getAllowOthersin interfaceService- Returns:
- true if remote connections are allowed
-
getType
Description copied from interface:ServiceGet the human readable short name of the service. -
getName
Description copied from interface:ServiceGet the human readable name of the service. -
formatType
Returns the name of the given type.- Parameters:
pgType- the PostgreSQL type oid- Returns:
- the name of the given type
-
convertType
Convert the SQL type to a PostgreSQL type- Parameters:
type- the SQL type- Returns:
- the PostgreSQL type
-
checkKeyAndGetDatabaseName
If no key is set, return the original database name. If a key is set, check if the key matches. If yes, return the correct database name. If not, throw an exception.- Parameters:
db- the key to test (or database name if no key is used)- Returns:
- the database name
- Throws:
DbException- if a key is set but doesn't match
-
isDaemon
public boolean isDaemon()Description copied from interface:ServiceCheck if a daemon thread should be used.
-