SqlContext.java 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package org.example.join.sql;
  2. import cn.hutool.core.util.ObjectUtil;
  3. import cn.hutool.core.util.StrUtil;
  4. import com.baomidou.mybatisplus.core.metadata.TableFieldInfo;
  5. import com.baomidou.mybatisplus.core.metadata.TableInfo;
  6. import com.baomidou.mybatisplus.core.metadata.TableInfoHelper;
  7. import com.baomidou.mybatisplus.core.toolkit.StringPool;
  8. import org.example.join.domain.IFormat;
  9. import org.example.join.domain.ITable;
  10. import org.example.join.domain.Table;
  11. import org.example.join.domain.TableJoin;
  12. import java.util.HashMap;
  13. import java.util.List;
  14. import java.util.Map;
  15. import java.util.StringJoiner;
  16. @SuppressWarnings("unchecked")
  17. public class SqlContext {
  18. private static final ThreadLocal<Map<String, Object>> threadLocal = new ThreadLocal<>();
  19. private static final String PARAM_NUMBER = "paramNumber";
  20. private static final String PARAM_MAP = "paramMap";
  21. private static final String TABLE_ALIAS_MAP = "tableAliasMap";
  22. public static void init(Map<String, Object> paramMap) {
  23. Map<String, Object> map = new HashMap<>();
  24. map.put(PARAM_NUMBER, 1);
  25. map.put(PARAM_MAP, paramMap);
  26. threadLocal.set(map);
  27. }
  28. public static void putValue(StringJoiner joiner, Object value) {
  29. if (value instanceof IFormat iFormat) {
  30. joiner.add(iFormat.toSql());
  31. } else {
  32. String mapKey = getParamKey();
  33. joiner.add(StringPool.HASH_LEFT_BRACE + mapKey + StringPool.RIGHT_BRACE);
  34. Map<String, Object> map = threadLocal.get();
  35. ((Map<String, Object>) map.get(PARAM_MAP)).put(mapKey, value);
  36. }
  37. }
  38. public static void remove() {
  39. threadLocal.remove();
  40. }
  41. public static String getTableAlias(Table table) {
  42. Map<String, String> tableAliasMap = getTableAliasMap();
  43. String tableAlias = table.getAlias();
  44. String tableName = table.getName();
  45. if (StrUtil.isBlank(tableAlias)) {
  46. tableAlias = tableAliasMap.get(tableName);
  47. if (StrUtil.isBlank(tableAlias)) {
  48. throw new IllegalArgumentException("未知连表:" + tableName);
  49. }
  50. }
  51. return tableAlias;
  52. }
  53. private static Map<String, String> createTableAliasMap(Sql<?> sql) {
  54. List<ITable> queryTableList = sql.queryTableList;
  55. int number = 1;
  56. Map<String, String> tableAliasMap = new HashMap<>();
  57. for (ITable iTable : queryTableList) {
  58. Table table;
  59. if (iTable instanceof Table item) {
  60. table = item;
  61. } else if (iTable instanceof TableJoin item) {
  62. table = item.getTable();
  63. } else {
  64. throw new IllegalArgumentException("未知ITable类型");
  65. }
  66. if (ObjectUtil.isEmpty(table.getAlias())) {
  67. if (tableAliasMap.containsKey(table.getName())) {
  68. throw new IllegalArgumentException(table.getName() + "表已存在,再次连表请取别名");
  69. }
  70. tableAliasMap.put(table.getName(), "t" + (number++));
  71. }
  72. }
  73. return tableAliasMap;
  74. }
  75. public static String getTableDelFlag(Table table) {
  76. TableInfo tableInfo = TableInfoHelper.getTableInfo(table.getName());
  77. if (!tableInfo.isWithLogicDelete()) {
  78. return null;
  79. }
  80. TableFieldInfo logicDeleteFieldInfo = tableInfo.getLogicDeleteFieldInfo();
  81. return logicDeleteFieldInfo.getColumn();
  82. }
  83. private static Map<String, String> getTableAliasMap() {
  84. Map<String, Object> map = threadLocal.get();
  85. return (Map<String, String>) map.get(TABLE_ALIAS_MAP);
  86. }
  87. public static void setTableAliasMap(Sql<?> sql) {
  88. Map<String, Object> map = threadLocal.get();
  89. map.put(TABLE_ALIAS_MAP, createTableAliasMap(sql));
  90. }
  91. private static String getParamKey() {
  92. Map<String, Object> map = threadLocal.get();
  93. int paramNumber = (int) map.get(PARAM_NUMBER);
  94. map.put(PARAM_NUMBER, paramNumber + 1);
  95. return SqlConstant.SQL_PARAM + paramNumber;
  96. }
  97. }