ColumnSelector.java 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. package com.gitee.gen.gen;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import java.util.Map;
  5. /**
  6. * 表信息查询
  7. */
  8. public abstract class ColumnSelector {
  9. private GeneratorConfig dataBaseConfig;
  10. public ColumnSelector(GeneratorConfig dataBaseConfig){
  11. this.dataBaseConfig = dataBaseConfig;
  12. }
  13. /**
  14. * 返回查询表字段信息的SQL语句,不同的数据查询表信息不一样
  15. * 如mysql是DESC tableName
  16. * @return
  17. */
  18. protected abstract String getColumnInfoSQL(String tableName);
  19. /**
  20. * 构建列信息
  21. * @param rowMap
  22. * @return
  23. */
  24. protected abstract ColumnDefinition buildColumnDefinition(Map<String, Object> rowMap);
  25. public List<ColumnDefinition> getColumnDefinitions(String tableName) {
  26. List<Map<String, Object>> resultList = SqlHelper.runSql(this.getDataBaseConfig(), getColumnInfoSQL(tableName));
  27. List<ColumnDefinition> columnDefinitionList = new ArrayList<ColumnDefinition>(resultList.size());
  28. // 构建columnDefinition
  29. for (Map<String, Object> rowMap : resultList) {
  30. columnDefinitionList.add(buildColumnDefinition(rowMap));
  31. }
  32. return columnDefinitionList;
  33. }
  34. public GeneratorConfig getDataBaseConfig() {
  35. return dataBaseConfig;
  36. }
  37. public void setDataBaseConfig(GeneratorConfig dataBaseConfig) {
  38. this.dataBaseConfig = dataBaseConfig;
  39. }
  40. }