Turso
Turso is the edge database based on libSQL - the open-source open-contribution fork of SQLite.
It enables you to place your data close to your users in over 35 locations around the world.
Usage
You can easily add Turso by using the following Qwik starter script:
pnpm run qwik add tursonpm run qwik add tursoyarn run qwik add tursobun run qwik add tursoThis command will add the necessary dependencies to use Turso.
It also adds new files inside your project folder:
- src/lib/turso.ts
and adds or modifies a .env.local file to include
PRIVATE_TURSO_DATABASE_URL=
PRIVATE_TURSO_AUTH_TOKEN=Using file databases
For local development and CI integration, it is ideal to use local database files.
First, check if SQLite is installed in your machine by running sqlite3 --version. If you get anything other than a version number (e.g 0-14 20:58:05 554764a6e721fab307c63a4f98cd958c8428a5d9d8edfde951858d6fd02daapl), visit this
link for installation instructions.
Proceed to create an SQLite file database by running the following command.
sqlite3 foo.dbCreate your database schema.
sqlite> create table todo (id integer not null, task text, done int default 0);Seed some data into your table.
sqlite> insert into todo(id, task) values(1, "Go to the gym");
sqlite> insert into todo(id, task) values(2, "Buy groceries");Quit the shell .quit
Then, assign the database file path to the PRIVATE_TURSO_DATABASE_URL environment variable
inside .env.local.
PRIVATE_TURSO_DATABASE_URL=file:foo.db
Note: A database token is not needed when working with file databases and
createClientmust be imported from@libsql/clientsince importing from@libsql/client/webdoes not support local file URLs.
Using a Turso database
When you want to deploy your project to production, you can then install the Turso CLI to your machine and create a Turso database.
Use the Turso CLI's db shell command to issue queries to your database.
turso db shell <database-name>Create your database schema.
โ  create table todo (id integer not null, task text, done int default 0);Seed some data into your table.
โ  insert into todo(id, task) values(1, "Go to the gym");
โ  insert into todo(id, task) values(2, "Buy groceries");Quit the shell .quit
Use the following instructions to obtain your Turso database credentials and assign them to the environment variables inside your deployment environment.
Starting with the database url, run the following command.
turso db show <database-name> --urlCopy the resulting URL and assign it to the PRIVATE_TURSO_DATABASE_URL environment variable.
And, for the database authentication token, run the command.
turso db tokens create <database-name>Copy the resulting token and assign it to the PRIVATE_TURSO_AUTH_TOKEN environment
variable.
How to use Turso inside Qwik
Import tursoClient inside your routes and initiate a database client instance
within Qwik's server-side APIs that expose the RequestEvent object, such as
routeLoader$(), routeAction$(), server$() and endpoint handlers such as
onGet, onPost, onRequest.
import { tursoClient } from "~/utils/turso";
 
export const useRouteLoader = routeLoader$(
  async (requestEvent: RequestEventBase) => {
    const client = tursoClient(requestEvent);
 
    const items = await client.execute("select * from table");
 
    return {
      items: items.rows,
    };
  }
);For more information, please visit the Turso docs.


