/** * Spring容器注入 */ private ResourceLoader resourceLoader; private ResourcePatternResolver resolver = ResourcePatternUtils.getResourcePatternResolver(resourceLoader); private MetadataReaderFactory metadataReaderFactory = new CachingMetadataReaderFactory(resourceLoader); private static final String FULLTEXT_SACN_PACKAGE_PATH = "fulltext.scan.package"; /** * set注入對象 */ public void setResourceLoader(ResourceLoader resourceLoader) { this.resourceLoader = resourceLoader; } /** * 利用spring提供的掃描包下面的類信息,再通過classfrom反射獲得類信息 * * @param scanPath * @return * @throws IOException */ public Set<Class<?>> doScan(String scanPath) throws IOException { Set<Class<?>> classes = new HashSet<Class<?>>(); String packageSearchPath = ResourcePatternResolver.CLASSPATH_ALL_URL_PREFIX .concat(ClassUtils.convertClassNameToResourcePath(SystemPropertyUtils.resolvePlaceholders(scanPath)) .concat("/**/*.class")); Resource[] resources = resolver.getResources(packageSearchPath); MetadataReader metadataReader = null; for (Resource resource : resources) { if (resource.isReadable()) { metadataReader = metadataReaderFactory.getMetadataReader(resource); try { if (metadataReader.getClassMetadata().isConcrete()) {// 當類型不是抽象類或接口在添加到集合 classes.add(Class.forName(metadataReader.getClassMetadata().getClassName())); } } catch (Exception e) { e.printStackTrace(); } } } return classes; }
還能插入代碼,哈哈哈哈,這樣好看多了。
只需要通過路徑就能獲取某個包下的所有實體。
得到了實體集合後
String name = class1.getAnnotation(Entity.class).tableName();
再獲取它的對應的表名。
然後就可以循環去做一些事情了。
六十多個表的業務差點讓我直接去世,有了這個分分鐘就查好了,還優化了代碼,提升了b格~~~~