Releases: elliotchance/vsql
Releases · elliotchance/vsql
v0.26.0
Adding support for SEQUENCEs (#142) A sequence is used as an atomic counter. It is useful for generating unique and sequential numbers. The sequence can have an separately optional min and max values, as well as being able to specify if numbers are allowed to cycle (wrap around) between these boundaries. New SQL statements introduced for `CREATE SEQUENCE`, `ALTER SEQUENCE` and `DROP SEQUENCE` as well as the `NEXT VALUE FOR <name>` expression. Fixes #139
v0.25.4
make: fix too lax loops in `make cli-test` and `make examples` (#140) * fix too lax `make cli-test` and `make examples` (make them fail, if any of the steps in their loops fail) * fix notice in vsql/sql_test.v * panic instead of continue, when connection_name is not found in connections
v0.25.3
ci: fix ci errors and warnings with latest V 0.3.2 4747e70 (#136) * ci: run `v fmt -w .` to make the CI pass again with latest `V 0.3.2 4747e70` * fix warnings about uninitialised reference fields, by explicitly setting them to nil by default * small cleanup, use os.getenv so that test runs can be parametrised more easily without changing the test source * ci: run tests on each individual PR as well, not just on master. Fix warnings/errors produced by yamllint. * document how to use TIMES=10 for running vsql/btree_test.v, in docs/testing.rst * fix `make docs` on Ubuntu 20.04 and `make cli-test` too Co-authored-by: Elliot Chance <elliotchance@gmail.com>
v0.25.2
refactor: Fix v syntax errors (#135) Some minor cleanup with V language and formatting changes.
v0.25.1
refactor: Fix V error syntax (#133) There was recently a change to the language which distinguishes `?` (as an optional none) vs `!` (as and optional error).
v0.25.0
Added `in` and `out` commands (#131) `vsql in` will execute a SQL file and `vsql out` can be used to dump the structure and data from a database in SQL format. These are also useful when converting data to and from other databases. The commands are designed to be simple and provide a means to make a lossless copy (or a backup) of a database without any other options: vsql out mydb.vsql > mydb.sql vsql in mydb.vsql < mydb.sql This is also especially important if there are changes to the vsql file format in the future. To be able to quickly and easily recreate the database. You can find more CLI options and documentation for these commands here: https://vsql.readthedocs.io/en/latest/cli.html To facilitate testing, there is now a 5th test suite called "CLI Tests" which are written as shell scripts and executed along with the other suites. This provides a lot of flexibility in testing CLI options, exit codes, outputs, etc. You can read how CLI Tests work here: https://vsql.readthedocs.io/en/latest/testing.html#cli
v0.24.4
All tables must belong to a schema (#129) The PUBLIC schema is now created when the database is created and any table that does not qualify a schema is placed into the PUBLIC schema. Have also added Connection.schemas() and Connection.schema_tables() for introspection.
v0.24.3
Documentation for V Client Library (#128) There is now a "V Client Library" page to properly document the public interface when using V to interact with vsql. To make this easier, a new feature has been created that will extract "snippets" from comments in V code and put them into `snippets.rst` for reference in the documentation. This will ensure that we only need to keep the docs in one place right within the code.
v0.24.2
Split vsql subcommands (#126) This splits each subcommand of vsql into its own V file. There will be new subcommands coming in the future and this will be cleaner. There is no change to functionality, other than you must use `vsql cli` explicitly now (rather than the implicit `vsql` without a subcommand). The Makefile has been updated to put the binary in bin/ which is a more regular location than in cmd/ previously.
v0.24.1
Non-reserved words can be used as identifiers (#127) Previously all <key words> (which includes reserved and non-reserved words) were disallowed as identifiers. Looking at the SQL standard more closely, it does explicitly state that reserved words cannot be regular identifiers using and case, but nowhere does it state that non-reserved words are not allowed to be used as identifiers. This is an import distinction because `public` is a non-reserved word and we intend to use it for the default schema and also for compatibility with the same schema in PostgreSQL. Also, comments can now be placed in `grammar.bnf` with a `#` at the start of the line (not within a line). See #103