-
-
Notifications
You must be signed in to change notification settings - Fork 601
Official_plugins
- General purpose plugins
- Database plugins
- SQL formatter plugins
-
Scripting languages plugins
- QtScript (built-in) (aka JavaScript)
- SQL (built-in)
- Tcl
- Python
- Exporting plugins
- Importing plugins
- Populating plugins
-
Syntax highlighter plugins
- SqliteHighlighter (built-in)
- QtScriptHighlighter (built-in) (aka JavaScript highlighter)
- Data editor plugins
- Custom config widget plugins
Database plugins provide support for various SQLite database formats.
Database plugin | Custom SQL functions | Custom collations | SQLite extensions | Encryption | BLOB support |
---|---|---|---|---|---|
DbSqlite3 | yes | yes | yes | no | yes |
DbSqlite2 | no | no | no | no | yes (*) |
DbSqliteCipher | yes | yes | yes | yes | yes |
DbSqliteWx | yes | yes | yes | yes | yes |
DbSqliteSystemData | yes | yes | yes | yes | yes |
DbAndroid | no | no | no | no | yes |
- (*) - BLOB support in SQLite 2 is limited, see possible issues.
This is a default plugin (that's why it's built-in) for databases. It always provides support for the most recent, official SQLite3 version.
Binary distributions of SQLiteStudio also have some SQLite extensions built in (currently only FTS in versions 1, 2, 3 and 4).
It doesn't support any encryption.
SQLiteStudio uses this plugin to store its own configuration.
DEPRECATED! It is deprecated as of SQLiteStudio 3.3.0. For accessing SQLite 2 please use older SQLiteStudio versions.
Enables support for an old SQLite 2. It comes with SQLite 2.8.17 on board.
Compilation notes: If you're compiling this plugin by yourself, be aware that it assumes that the SQLite 2 library was compiled with UTF-8 support.
It enables support for SQLCipher databases in SQLiteStudio.
More details here.
Enables support for wxSQLite3 databases (part of wxWidgets). Home page of wxSQLite3: https://github.com/utelle/wxsqlite3.
Since version 3.3.0 of SQLiteStudio the plugin makes use of SQLite3MultipleCiphers for implementing support to all wxSQLite3, System.Data.SQLite and SQLCipher databases.
DEPRECATED! This plugin is deprecated as of SQLiteStudio 3.3.0. Accessing System.Data.SQLite databases is now provided by the DbSqliteWx plugin.
Enables support for System.Data.SQLite databases. This plugin is available only under Windows, because it relies on Windows API. Home page of System.Data.SQLite is https://system.data.sqlite.org/index.html/doc/trunk/www/index.wiki
It enables SQLiteStudio to access SQLite databases directly on the Android device. No need to pull and push database files. All queries and changes are executed directly on the device.
More details here.
SQL formatter plugins are used by the SQL formater service in SQLiteStudio to format SQL statements in text input fields that are used to display SQL. That includes SQL Editor, View window, Trigger Dialog and many more.
These plugins can provide their own configuration options available in Configuration Dialog, under Plugins -> SQL Formatting -> PluginName.
Simple formatter is more for an example (for developers) of how the formatter plugins work and how to implement them. It has very little of configuration options and doesn't provide much of a formatting. It basicly can uppercase keywords and reduce multiple whitespace characters into single one (excluding whitespaces in string values).
Scripting languages plugins are used in various ways across the application. Using provided scripting languages you can implement:
QtScript implements ECMAScript language, which is pretty much what JavaScript is. For more details see ScriptingQt.
SQL scripting plugin is a very limited one. Its main purpose was to allow writing kind of procedures (since SQLite lacks procuders), using custom SQL functions. One would implement custom SQL function with SQL scripting plugin, put various SQL statements in the implementation and then execute such "procedure" with: SELECT
my_procedure(arg1,
arg2)
.
Function code that uses SQL as an implementation language can refer to input arguments using following placeholders:
:argName
@argName
$argName
For example if you implement function, that have 2 input arguments named "primary_id" and "secondary_id", you can write query like:
DELETE FROM some_table WHERE pr_id = @primary_id AND sec_id = :secondary_id;
Using SQL scripting plugin is allowed in any other contexts, where scritping plugins are used (obviously), but SQL is not really a programming language, so it's not a good candidate for using it anywhere else.
Implements Tcl scripting language support.
For more details see ScriptingTcl.
Python plugin requires the Python 3.9 to be installed in your system. Version 3.9 is required at least for the plugin version provided in SQLiteStudio 3.4.0. Future versions may depend on more recent Python versions and should be documented here when that happens.
At the moment no further documentation for this plugin is provided.
Using this plugin you can make a dump of the entire database (or only some of its elements) into SQL file, which can be later executed on any database, to recreate the exactly same objects and data. You can also export results of a query, which can be later imported (executed) into other database. Files created by this plugin look more or less like this:
CREATE TABLE table1 (id INTEGER, val TEXT);
INSERT INTO table1 (id, val) VALUES (1, 'abc');
INSERT INTO table1 (id, val) VALUES (2, 'xyz');
INSERT INTO table1 (id, val) VALUES (3, 'qwerty');
CREATE INDEX idx1 ON table1 (id);
CREATE VIEW view1 AS SELECT val FROM table1 WHERE id > 2;
Importing plugins are usually used from Import Dialog window. However they also can be used by executing a SELECT
query on the import()
function, like in the example below:
SELECT import('c:/test.csv', 'CSV', 'my_table1', 'UTF-8', 'CsvImport.Separator=1');
This will perform importing from the C:/test.csv
file, using CSV plugin and the data will be put into my_table1
table. UTF-8 will be used as charset for reading data from input file. The last argument (plugin options) depends on importing plugin used and is different, depending on the plugin chosen. Detailed description of each plugin below contains also a set of options that can be put into the last argument.
Complete list of options supported by any importing plugin can be learned by executing SELECT
import_options('CSV')
.
If you'd like to provide more than one option at single import()
call, then put each option in a new line, like this:
SELECT import('c:/test.csv', 'CSV', 'my_table1', 'UTF-8', 'CsvImport.Separator=1
CsvImport.FirstRowAsColumns=true');
Imports data from CSV files.
See CsvImport for more details and usage examples.
This plugin imports certain parts of text using regular expression.
See RegExpImport for more details and usage examples.
Syntax highlighter plugins are used in any input text field that displays some code. Examples of such fields is SQL Editor, Custom SQL functions window, Custom collations window, etc.
Supports SQL understood by SQLite 3 (which covers SQLite 2 as well).
Supports QtScript, which is more or less the same as JavaScript (aka ECMAScript).
Data editor plugins provide widgets for editing specific data formats. For example it is handy to edit a numbers in a spinbox, or a date in a calendar widget. For simple types there are several editors built into SQLiteStudio. Data editor plugins can provide additional widgets to support more specialized data formats, like displaying image, highlight programming lanugage source code, etc.
These plugins only matter to developers. Regular users won't see anything added by these plugins.
Since SQLiteStudio provides easy way for binding configuration to widgets on UI forms, some of configuration options might require unusual handling by complex widgets. Custom config widgets provide logic for how to handle those config options using widget provided on UI form. More details in developers manual.