Team Edition Documentation

DOWNLOAD pdf

AI Smart Assistance

Team Edition offers the ability to construct SQL queries using natural language through our AI smart completion and AI Chat features. This capability is achieved through integrations with OpenAI's GPT language model, Azure OpenAI, Google Gemini and Ollama.

Note: Team Edition is not affiliated with OpenAI, Microsoft Azure, or Google. Integration with AI features is achieved through the public APIs of OpenAI's GPT, Azure OpenAI Service, and Google Gemini.

Understanding the AI integration in Team Edition

With the AI smart completion feature, you can type queries in natural language and Team Edition will convert them into SQL statements. This tool simplifies writing complex queries by interpreting your input and automatically generating the correct SQL code.

The AI Chat feature provides a conversational interface, allowing you to communicate with the database in plain language. Type your queries conversationally, and AI Chat translates them into executable SQL, streamlining your database interactions.

Initial setup

To activate the AI features in Team Edition, configure the API token:

  1. Navigate to Window -> Preferences -> General -> AI.

  2. Ensure the Enable smart completion option is activated. This option is typically enabled by default in the PRO versions.

  3. In the API token field, input your AI secret key.

  4. Save the changes. See the Basic configuration for secret key details.

For instructions on utilizing the AI features, visit the AI Smart completion usage and AI Chat usage sections.

Data privacy

We prioritize data safety and user privacy. In this section, we outline how data is managed and the measures taken to protect user privacy when using the AI features.

To enable the AI features capabilities, table and column names from the current database schema are transmitted to OpenAI. This step is crucial for accurately translating user requests into SQL queries. Key considerations regarding data privacy are as follows:

  • No Table Data: Only metadata like table and column names are shared with OpenAI. Actual table data is not transmitted.
  • User Consent: On the first use of AI completion for a specific connection, Team Edition will prompt for your confirmation to send metadata. This confirmation is mandatory to use the feature.

  • Log Transparency: The entire request can be logged for your review. To enable this, navigate to Preferences and check the Write GPT queries to debug log option.

  • Selective Metadata Sharing: If you prefer not to share information about certain tables, adjust the tables in scope using the Scope field.
  • Disabling AI: PRO version users can turn off the AI feature, while Community Edition users can avoid it by not installing the AI plugin.
  • Azure OpenAI privacy: If you use Azure OpenAI, be aware that it operates under its own privacy policy. It's recommended to review their terms before using.
  • Google Gemini privacy: When utilizing Google Gemini, it is important to understand the specific data privacy measures.

AI settings and customization

To utilize the AI-enhanced functionalities within Team Edition, certain configurations and setup processes are required. This section offers a comprehensive guide on initial setup, advanced configurations for PRO users, and customization options to tailor the AI integration according to specific preferences.

Basic configuration

By default, AI features are ready to use. To start, you need to specify the service credentials based on the AI service you choose: OpenAI, Azure AI, Ollama or Google Gemini.

Credentials for OpenAI
  1. Sign up on the OpenAI platform.

  2. Navigate to the API Keys section and generate a new secret key.

  3. Insert this key into Team Edition's API token setting.

Here is a list of the currently supported models:

  • gpt-3.5-turbo (recommended for SQL).
  • gpt-3.5-turbo-instruct.
  • gpt-4.
  • gpt-4-turbo.
  • gpt-4o.
  • gpt-4o-mini.

Note: OpenAI services are available in specific countries. Consult the supported countries list to verify availability in your location.

Credentials for Azure AI
  1. Sign up on the Azure platform.

  2. Navigate to the Azure Portal and create a new AI service under the AI + Machine Learning section.

  3. Generate and copy the credentials for the newly created service.

  4. Insert these credentials into Team Edition's Engine Settings.

Credentials for Google Gemini
  1. Sign up on the Google Cloud Platform.

  2. Navigate to the Google Cloud Console and create a new project.

  3. Enable the Gemini API for your project by searching for the Gemini API in the marketplace and clicking Enable.

  4. Create credentials for your project by navigating to the Credentials page under APIs & Services. Choose Create credentials and select the appropriate type for your Gemini integration.

  5. Copy the generated credentials.

  6. Insert these credentials into Team Edition's Engine Settings.

Note: Google Gemini services are subject to regional availability. Check the list of available regions to ensure access in your area.

Credentials for Ollama

Ensure that Ollama is already installed and running on a server. You will need the host address where Ollama is installed to proceed.

  1. Specify the host address of your Ollama server in the Instance host field, ensuring it follows the format http://host:port.
  2. Click Load Models. If the host address is correct, Team Edition will display the available models from your Ollama server in the Model dropdown menu.
  3. Select the model you need for your integration.

Preferences

For specific requirements or troubleshooting, you might want to adjust some of the following settings:

  • Navigate to Window -> Preferences -> General -> AI to access these settings.

Setting Description
Enable smart completion Displays the AI features in the SQL Editor.
Include source in query comment Shows your original request above the AI-generated query in the SQL Editor.
Execute SQL immediately Runs the translated SQL query immediately after generation.
Send attribute type information Send attribute type information to the AI vendor. It makes better completion, but consumes more tokens.
Send object description Send object description to the AI vendor. Improves completion, but may consume significant amount of tokens.
API token Input your secret key from the OpenAI platform.
Model Choose the AI model.
Temperature Control AI's creativity from 0.0 (more precise) to 0.9 (more diverse).
Note that higher temperature can lead to less predictable results.
Write GPT/Ollama queries to debug log Logs your AI requests.

PRO version exclusive settings

Setting Description
Send foreign keys information Helps AI understand table relationships.
Send unique keys and indexes information Assists AI in crafting complex queries.
Format SQL query Adds formatting to the generated SQL.
Table join rule Choose between explicit JOIN or JOIN with sub-queries.

There is also an option to switch the Service between OpenAI, Azure OpenAI, Google Gemini and Ollama.

Azure provides a set of distinct settings:

Setting Description
Endpoint Configure a custom endpoint URL for Azure OpenAPI interactions.
API version Select the version of the API you wish to use.
Deployment Specify the deployment name chosen during model deployment.
Context size Choose the context size between 2048 and 32768. A larger number allows the AI to use more data for better answers but may slow down response time. Choose based on your balance of accuracy and speed.

Utilizing AI capabilities in Team Edition

AI Chat usage

To utilize the AI Chat feature in Team Edition:

  1. Launch the SQL Editor.

  2. Click on the AI Chat tab , located on the right toolbar of the SQL Editor.

  3. In the chat window that opens, input your request in natural language.

  4. Press the Send button to get the SQL translation.

  5. To execute the SQL query generated by AI, click the Execute SQL query button.

Note: The AI Chat logs your query history, enabling you to reference and expand on prior inputs. Each new or edited entry prompts the AI to generate a revised SQL query.

Resetting query context

To start a new conversation or to change the query context in the AI Chat, you can use one of the two reset options available:

  • To clear the entire history, use the reset button located next to the Save button.
  • To clear a portion of the conversation history up to a chosen point, use the reset option within the AI Chat itself, located at the end of each user's input prompt.

Defining the scope in AI Chat

For enhanced precision, especially in databases with extensive schemas, you can specify database objects in the Scope field to narrow down the context.

  1. In the AI Chat interface, click on the arrow near the Change scope button to open the context menu.

  2. Specify the area of your database that the AI should concentrate on.

  3. You can choose from:

    • Current Schema: Focuses the AI on the schema you are currently using.
    • Current Database: Limits the AI to the database currently selected.
    • Connection: Sets the AI to consider all schemas within the current database connection.
    • Custom: Allows you to define a more specific scope, such as a particular table or schema.

AI smart completion usage

To interact with databases using the AI Smart completion feature:

  1. Launch the SQL Editor.

  2. Click on the GPT Chat smart completion icon located in the left toolbar of the SQL Editor. > Note The toolbar is customizable. For further information, refer to Toolbar Customization article.

  3. Input your natural language request in the AI smart completion window.

  4. Click Translate to obtain the SQL query.

For enhanced precision, especially in databases with extensive schemas, you can specify database objects in the Scope field to narrow down the context.

Defining the scope

To enhance the precision of AI-assisted SQL queries, especially in extensive database schemas, setting the scope is key. This action narrows down the AI's focus, ensuring it generates more relevant queries.

  1. In the AI Smart completion interface, navigate to the Scope field.

  2. You can choose from:

    • Current Schema: Focuses the AI on the schema you are currently using.
    • Current Database: Limits the AI to the database currently selected.
    • Connection: Sets the AI to consider all schemas within the current database connection.
    • Custom: Allows you to define a more specific scope, such as a particular table or schema.
Accessing query history

Query history allows you to review previous requests. In the PRO version, this includes history from past sessions, offering a track record of your SQL queries and AI interactions.

Disabling AI features

To hide the GPT smart completion and AI Chat icons in the SQL Editor:

  • Navigate to Window -> Preferences -> General -> AI.
  • Deselect Enable smart completion.

For users with PRO versions wanting to permanently disable this feature:

  • Use the system variable by setting DBEAVER_AI_DISABLED to true.
  • Or, add Dai.disabled=true to the dbeaver.ini file.

Detailed instructions on finding dbeaver.ini are available in our article.

Note: Once this feature is permanently disabled in PRO versions, it cannot be re-enabled via Preferences.

Best practices for question formulation

When using AI to generate SQL queries, it's essential to provide clear and specific input. Here's how to optimize your questions:

  • Language: While AI supports multiple languages, it's recommended to use English for best results.
  • Database knowledge: Familiarity with your database structure enhances the accuracy of generated queries.
  • Iterative refinement: Start with a general request and refine iteratively. As you provide more specific details, the AI's output will become more relevant.
  • Explicit details: If you know certain tables or columns that should be part of the query, include them in your request for better accuracy.

Example 1: "List all customers from Italy"

Resulting SQL:

SELECT *
FROM customers
WHERE country = 'Italy';

Example 2: "montre les clients de France"

SELECT *
FROM customer
WHERE country = 'France';

Example 3: "show customers who purchased blues tracks, use joins"

SELECT c.FirstName, c.LastName, t.Name, g.Name
FROM Customer c
         JOIN Invoice i ON c.CustomerId = i.CustomerId
         JOIN InvoiceLine il ON i.InvoiceId = il.InvoiceId
         JOIN Track t ON il.TrackId = t.TrackId
         JOIN Genre g ON t.GenreId = g.GenreId
WHERE g.Name = 'Blues'
ORDER BY c.LastName, c.FirstName;

Example 4: "get names of customers who purchased blues tracks, use joins"

SELECT DISTINCT c.FirstName, c.LastName
FROM Customer c
         JOIN Invoice i ON c.CustomerId = i.CustomerId
         JOIN InvoiceLine il ON i.InvoiceId = il.InvoiceId
         JOIN Track t ON il.TrackId = t.TrackId
         JOIN Genre g ON t.GenreId = g.GenreId
WHERE g.Name = 'Blues';