Connection
Understanding Connections in RestBI
A Connection
is the bridge between your application and the database where your data resides. It encapsulates all the necessary details to connect to your database, such as the host, port, user credentials, and the type of database you're working with. A well-defined connection ensures that RestBI can seamlessly interact with your data sources, enabling you to execute queries and retrieve data efficiently.
Connection Object Structure
The Connection object in RestBI defines all the necessary details to connect to a database. Below is an example connection object for a PostgreSQL database:
Connection Reference
id
A unique identifier for the connection.
name
The name of the connection, used for reference within the model.
host
The hostname or IP address of the database server.
port
The port number on which the database server is listening.
user
The username used to authenticate with the database.
password
The password used to authenticate with the database.
database
The name of the specific database to connect to.
type
The type of database (e.g., POSTGRES
, MYSQL
, SQL_SERVER
, etc.), represented by the DatabaseType
enum.
Where Can Connection Details Be Stored?
To ensure security and flexibility, connection details should be stored as code in configuration files, preferably outside your main application logic. This approach allows you to:
Easily switch connections: For example, from a test database to a production database.
Version control: Track changes to connection details using version control systems.
Environment-specific configurations: Store different connections for different environments, ensuring your application always connects to the correct database.
Switching Connections
One of the key benefits of using Connection objects in RestBI is the ability to switch between connections easily. For instance, you might have a development database and a production database. By simply swapping the connection object, you can run your queries against different data sources without changing your application code.
Here’s how you can swap connections:
Security Considerations
While connections are powerful, they must be handled securely:
Environment Variables: Store sensitive information such as passwords in environment variables rather than hardcoding them in your application.
Secrets Management: Consider using a secrets management service to securely store and access sensitive connection details.
Further Reading
Last updated