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
var tedious = require("../../lib/tedious");
var Request = tedious.Request;
var TYPES = tedious.TYPES;
 
var common = require("../common");
 
var connection;
common.createBenchmark({
  name: "inserting varbinary(max) with 50 MiB",
 
  profileIterations: 20,
 
  setup: function(cb) {
    common.createConnection(function(_connection) {
      connection = _connection;
 
      var request = new Request("CREATE TABLE #benchmark ([value] varbinary(max))", function(err) {
        if (err) return cb(err);
 
        var request = new Request("INSERT INTO #benchmark ([value]) VALUES (@value)", cb);
        var buf = Buffer.alloc(50 * 1024 * 1024);
        buf.fill("x");
        request.addParameter("value", TYPES.VarBinary, buf);
        connection.execSql(request);
      });
 
      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);
  }
});