333
schangxiang@126.com
2025-09-19 18966e02fb573c7e2bb0c6426ed792b38b910940
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
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);
  }
});