@tidbcloud/serverless
v0.3.0
Published
TiDB Cloud Serverless Driver
Readme
TiDB Cloud Serverless Driver for JavaScript
This driver is for serverless and edge compute platforms that require HTTP external connections, such as Vercel Edge Functions or Cloudflare Workers.
There are three ways to use the driver:
- Stateless connection (default): each query is independent, ideal for edge environments with short-lived, frequently created connections.
- Stateful connection (experimental): use it when you require session.
- Transaction (experimental): use it when you require interactive transaction.
Usage
Install
You can install the driver with npm:
npm install @tidbcloud/serverlessStateless Connection
To query from TiDB Serverless, you need to create a connection first. Then you can use the connection to execute raw SQL queries.
import { connect } from '@tidbcloud/serverless'
const conn = connect({url: 'mysql://username:password@host/database'})
const results = await conn.execute('select * from test where id = ?',[1])Stateful Connection (experimental)
If you want to keep session state across multiple queries, create a stateful connection. Remember to call close() to release the connection, or you may reach the connection limits.
Note:
Connections idle for 10 minutes will be closed automatically. The Stateful connection is not concurrent-safe. You are not allowed to run SQLs parallel in the same stateful connection.
import { connect } from '@tidbcloud/serverless'
const conn = connect({url: 'mysql://username:password@host/database'})
const stateful = await conn.persist()
try {
const r1 = await stateful.execute('use db2')
const r2 = await stateful.execute('select * from test where id = ?', [2])
} finally {
await stateful.close()
}Transaction (experimental)
You can also perform interactive transactions with the serverless driver. For example:
Note:
Transactions idle for 10 minutes will be rolled back automatically if it has not been committed or rolled back. The transaction is not concurrent-safe. You are not allowed to run SQLs parallel in the same transaction.
import { connect } from '@tidbcloud/serverless'
const conn = connect({url: 'mysql://username:password@host/database'})
const tx = await conn.begin()
try {
await tx.execute('insert into test values (1)')
await tx.execute('select * from test')
await tx.commit()
}catch (err) {
await tx.rollback()
throw err
}Edge example
The serverless driver is suitable for the edge environments. See how to use it with Vercel Edge Functions:
import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';
import { connect } from '@tidbcloud/serverless'
export const runtime = 'edge'
export async function GET(request: NextRequest) {
const conn = connect({url: process.env.DATABASE_URL})
const result = await conn.execute('show tables')
return NextResponse.json({result});
}See TiDB Cloud Serverless Driver documentation to learn more.
MCP for AI Agent
Do not use it in production.
{
"mcpServers": {
"tidbcloud-serverless-mcp": {
"command": "npx",
"args": ["-y", "@tidbcloud/serverless-mcp"],
"env": {
"TIDB_DATABASE_URL": "mysql://<user>:<password>@<host>/<database>"
}
}
}
}Configuration
See Configure TiDB Cloud Serverless Driver.
License
Apache 2.0, see LICENSE.
