sql_builder.test.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /**
  2. * sql拼接器单元测试
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/10/20
  6. * @version
  7. */
  8. 'use strict';
  9. const { app, assert } = require('egg-mock/bootstrap');
  10. const SqlBuilder = require('../../../app/lib/sql_builder');
  11. describe('test/app/lib/sql_builder.test.js', () => {
  12. it('set where like', function* () {
  13. const sqlBuilder = new SqlBuilder();
  14. sqlBuilder.setAndWhere('field', {
  15. value: app.mysql.escape('value%'),
  16. operate: 'like',
  17. });
  18. const [sql, param] = sqlBuilder.build('table');
  19. const finalSql = app.mysql.format(sql, param);
  20. // 最后组合后应该获得的数据
  21. const matchSql = "SELECT * FROM `table` WHERE `field` like 'value%'";
  22. assert(finalSql === matchSql);
  23. });
  24. it('set normal sql', function* () {
  25. const sqlBuilder = new SqlBuilder();
  26. sqlBuilder.columns = ['id'];
  27. sqlBuilder.limit = 10;
  28. sqlBuilder.offset = 1;
  29. sqlBuilder.orderBy = [['id', 'DESC']];
  30. const [sql, param] = sqlBuilder.build('table');
  31. const finalSql = app.mysql.format(sql, param);
  32. // 最后组合后应该获得的数据
  33. const matchSql = 'SELECT `id` FROM `table` LIMIT 1,10 ORDER BY `id` DESC';
  34. assert(finalSql === matchSql);
  35. });
  36. it('where in sql', function* () {
  37. const sqlBuilder = new SqlBuilder();
  38. sqlBuilder.columns = ['id'];
  39. sqlBuilder.limit = 10;
  40. sqlBuilder.offset = 1;
  41. sqlBuilder.orderBy = [['id', 'DESC']];
  42. sqlBuilder.setAndWhere('id', {
  43. value: [1, 2, 3, 4],
  44. operate: 'in',
  45. });
  46. const [sql, sqlParam] = sqlBuilder.build('table');
  47. const finalSql = app.mysql.format(sql, sqlParam);
  48. const matchSql = 'SELECT `id` FROM `table` WHERE `id` IN (1,2,3,4) LIMIT 1,10 ORDER BY `id` DESC';
  49. assert(matchSql === finalSql);
  50. });
  51. it('update sql', function* () {
  52. const sqlBuilder = new SqlBuilder();
  53. sqlBuilder.setUpdateData('create_time', {
  54. value: 1,
  55. selfOperate: '+',
  56. });
  57. sqlBuilder.setUpdateData('office', {
  58. value: 2,
  59. });
  60. sqlBuilder.setUpdateData('full_path', {
  61. value: ['`full_path`', app.mysql.escape('1.'), app.mysql.escape('2.')],
  62. literal: 'Replace',
  63. });
  64. sqlBuilder.setAndWhere('group_id', {
  65. value: 1,
  66. operate: '>=',
  67. });
  68. const [sql, sqlParam] = sqlBuilder.build('table', 'update');
  69. const finalSql = app.mysql.format(sql, sqlParam);
  70. const matchSql = "UPDATE `table` SET `create_time` = IF(IsNull(`create_time`), 0, `create_time`) + 1, `office` = 2, `full_path` = Replace(`full_path`,'1.','2.') WHERE `group_id` >= 1";
  71. assert(finalSql === matchSql);
  72. });
  73. it('delete sql', function* () {
  74. const sqlBuilder = new SqlBuilder();
  75. sqlBuilder.setAndWhere('office', {
  76. value: 2,
  77. operate: '=',
  78. });
  79. const prePath = '1.2.3';
  80. sqlBuilder.setAndWhere('path', {
  81. value: app.mysql.escape(prePath + '%'),
  82. operate: 'Like',
  83. });
  84. const [sql, sqlParam] = sqlBuilder.build('table', 'delete');
  85. const finalSql = app.mysql.format(sql, sqlParam);
  86. const matchSql = "DELETE FROM `table` WHERE `office` = 2 AND `path` Like '1.2.3%'";
  87. assert(finalSql === matchSql);
  88. });
  89. });