本文整理匯總了TypeScript中mysql2Types.IConnection.query方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript IConnection.query方法的具體用法?TypeScript IConnection.query怎麽用?TypeScript IConnection.query使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類mysql2Types.IConnection
的用法示例。
在下文中一共展示了IConnection.query方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: rootTransaction
/**
* Create and execute a stored procedure as root.
*/
async rootTransaction(body: string): Promise<void> {
// Hash proc body to get a unique proc name.
// This makes sure we have a unique name for each proc operation.
const name = this.getProcedureName(body);
const transactionQuery = `
CREATE PROCEDURE \`${name}\`()
BEGIN
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION
BEGIN
ROLLBACK;
RESIGNAL;
END;
START TRANSACTION;
${body}
COMMIT;
END;`;
// Ensure root.
await this.ensureRootConnection();
// Here we'll try to create the proc, but if the proc name
// already exists we can be sure it's the same operation
// so we will trap the error and call the pre-defined proc.
try {
await this.rootConn.query(transactionQuery);
} catch (err) {
// If proc already exists, we are good to go.
if (err.code !== 'ER_SP_ALREADY_EXISTS') {
throw err;
}
}
// Attempting to call proc.
await this.callProc(name);
}
示例2: rootQuery
/**
* Execute a regular query on the root connection.
*/
async rootQuery(sql: string): Promise<any> {
await this.ensureRootConnection();
return this.rootConn.query(sql);
}
示例3: callProc
/**
* Call a stored procedure by procedure name generated in getProcedureName.
*/
async callProc(name: string): Promise<any> {
return this.rootConn.query(`CALL \`${name}\``);
}