public List<T> findById(Object id) throws NoSuchFieldException { StringBuffer sb=new StringBuffer("select * from "); TableName tableName=(TableName) clazz.getAnnotation(TableName.class); if (tableName==null){ throw new RuntimeException("未使用注解标记表名"); } String name = tableName.name(); sb.append(name+" where "); Field declaredField = clazz.getDeclaredField("id"); TableField tableField = declaredField.getAnnotation(TableField.class); if (tableField!=null) { sb.append(tableField.value() + "='" + id + "'"); } List<T> list = find(sb.toString()); return list; }
时间: 2024-04-28 14:18:40 浏览: 95
spring-boot List转Page的方法步骤
这段代码看起来是一个基于注解的ORM框架中的查询方法,目的是根据传入的id值查询对应的数据。可以看到,首先根据clazz获取到了表名的注解值,然后拼接SQL语句,接着通过反射获取到id字段的注解值,最后调用find方法进行查询并返回结果。需要注意的是,如果没有使用注解标记表名,则会抛出RuntimeException异常。
阅读全文