@vuept/loopback-connector-mssql
Version:
Microsoft SQL Server connector for LoopBack
50 lines (38 loc) • 1.38 kB
JavaScript
var tedious = require("../../lib/tedious");
var Request = tedious.Request;
var TYPES = tedious.TYPES;
var async = require("async");
var common = require("../common");
var connection;
common.createBenchmark({
name: "Many result rows",
profileIterations: 10,
setup: function(cb) {
common.createConnection(function(_connection) {
connection = _connection;
var request = new Request("CREATE TABLE #benchmark ([id] int IDENTITY(1,1), [name] nvarchar(100), [description] nvarchar(max))", function(err) {
if (err) return cb(err);
async.timesSeries(10000, function(n, next) {
var request = new Request("INSERT INTO #benchmark ([name], [description]) VALUES (@name, @description)", next);
request.addParameter("name", TYPES.NVarChar, "Row " + n);
request.addParameter("description", TYPES.NVarChar, "Example Test Description for Row " + n);
connection.execSql(request);
}, cb);
});
connection.execSqlBatch(request);
});
},
exec: function(cb) {
var request = new Request("SELECT * FROM #benchmark", cb);
connection.execSql(request);
},
teardown: function(cb) {
var request = new Request("DROP TABLE #benchmark", function(err) {
if (err) {
return cb(err);
}
connection.close();
});
connection.execSqlBatch(request);
}
});