MySQL

MySQL Start Guide

1. Connections

Connection example:

{
  "name": "MySQL",
  "server": "localhost",
  "driver": "MySQL",
  "port": 3306,
  "database": "test_db",
  "username": "root",
  "askForPassword": false,
  "password": "root",
  "connectionTimeout": 15
}

Using a socket file example:

{
  "name": "MySQL",
  "driver": "MySQL",
  "database": "test_db",
  "username": "root",
  "askForPassword": false,
  "password": "root",
  "connectionTimeout": 15,
  "socketPath": "/path/to/mysqld.sock"
}

1.1 Specific Options

MySQL driver specific options can be passed using mysqlOptions settings.

{
  "name": "MySQL",
  "server": "localhost",
  "driver": "MySQL",
  "port": 5433,
  "database": "test_db",
  "username": "root",
  "askForPassword": false,
  "password": "root",
  "connectionTimeout": 15,
  "mysqlOptions": {
    ... // options See section 2. mysqlOptions
  }
}

2. mysqlOptions

We have two options of connectors for MySQL. You can choose which one to use by change the setting mysqlOptions.authProtocol. The allowed values are default and xprotocol, we use default by default since is the most often used.

Extra options can be used as defined in the connectors documentation.

They will be passed to the pool constructor directly. See https://github.com/mtxr/vscode-sqltools/blob/master/packages/core/driver/mysql/index.ts .

Know Errors and How to Fix

MySQL 8 and ER_NOT_SUPPORTED_AUTH_MODE

Potential solutions:

  • Ensure you’ve set authProtocol to xprotocol
  • Add a trailing 0 to the port. See the MySQL Guide to Ports

Example configuration:

{
  "sqltools.connections": [
    {
      "askForPassword": true,
      "connectionTimeout": 30,
      "driver": "MySQL",
      "name": "LocalHost",
      "port": 33060,
      "server": "127.0.0.1",
      "username": "root",
      "mysqlOptions": {
        "authProtocol": "xprotocol"
      }
    }
  ]
}

Connection Options

askForPasswordboolean

Ask for password at connection time instead of storing it as plaintext in your settings.

Typeboolean
Default Valuefalse
connectionTimeoutnumber

Connection timeout in seconds.

Typenumber
Default Value15
connectStringstring | null

Connect string. Support for Oracle, PostgreSQL and AWS Redshift.

Typestring or null
cqlOptionsobject | null

See https://docs.datastax.com/en/developer/nodejs-driver/4.1/api/type.ClientOptions/ for more details.

Typeobject or null
Default Value{}
databasestring

Database name.

Typestring
dialectstring

Connection Driver

Typestring
driverstring

Connection driver used for this connection.

Typestring
groupstring

Connection group name.

Typestring
mysqlOptionsobject | null

See https://vscode-sqltools.mteixeira.dev/en/drivers/my-sql#2-mysqloptions for more details.

Typeobject or null
Default Value{}
Object Properties
PropertyDescriptionType
authProtocolstring
  • xprotocol
  • default
sslboolean, object, string or null
namestring

Connection name.

Typestring
passwordstring | null

Connection password

Typestring or null
portnumber

Port for connection.

Typenumber
previewLimitnumber

Maximum number of records to return in table previews.

Typenumber
Default Value50
serverstring

Server address.

Typestring
Default Value127.0.0.1
socketPathstring

Path of socket file to connect using UNIX sockets. MySQL only for now.

Typestring
usernamestring

Connection username.

Typestring
variablesobject | null

Connection variables in a key/value pair format. Use this property with sqltools.queryParams.enableReplace to replace the variables without prompting.

Typeobject or null
Default Valuenull
Object Properties
PropertyDescriptionType
×