那就得看用的是什么数据库了,比如mysql可以用describe
tablename返回一个resultset,其他数据库没试过,应该也有类似方法的;或者比如oracle,可以用select
from
tablename
where
rownum
<=
1来确保只取一条记录,然后用1楼的方法
查询某几列时返回的结果是装有object数组的list
List<Object[]> list=SightdemoDaoquerysightdemo(detilParam);
for(int i=0;i<listsize();i++){
Object[] le=listget(i);
Systemoutprintln(le[0]);
Systemoutprintln(le[1]);
}
反射获取Java类的所有字段,包括所有父类中的字段。类自身的字段可直接通过方法getDeclaredFields()(获取所有修饰符字段)或者getFields()(获取public修饰的字段)获取,但父类中的字段暂时没有发现直接获取的方式。 需要递归获取所有的父类,然后获取他们的字段,最终获取到类的所有字段。
如果要获取字段值,则需要设置字段可访问:fieldsetAccessible(true); field为reflect包下的Field类
案例:
1、父类
package comcarlstudyspringbootbean; import lombokData; import lombokexperimentalAccessors; / @author changez @desc @date 2019/3/10 11:30 / @Data @Accessors(chain = true) public class BeanBasic { private Integer id; private Long createTime; private Long updateTime; }
2、子类
package comcarlstudyspringbootbean; import lombokData; import lombokEqualsAndHashCode; import lombokToString; import lombokexperimentalAccessors; / @author changez @desc @date 2019/3/10 11:17 / @Data @EqualsAndHashCode(callSuper = true) @ToString(callSuper = true) @Accessors(chain = true) public class Student extends BeanBasic{ private String name; private String address; }
3、测试类
package testlombok; import comcarlstudyspringbootbeanStudent; import orgjunitTest; import javalangreflectField; import javautilArrayList; import javautilArrays; import javautilList; / @author changez @desc Java反射获取类的所有属性 @date 2019/3/10 11:41 / public class LombokTest { @Test public void getParentField(){ Student stu1 = new Student(); stu1setName("student-name") setAddress("student1-address") setId(1) setCreateTime(20190310140423L) setUpdateTime(20190310140423L) ; Class clazz = Studentclass; List allFields = new ArrayList(100); // 获取当前对象的所有属性字段 // clazzgetFields():获取public修饰的字段 // clazzgetDeclaredFields(): 获取所有的字段包括private修饰的字段 allFieldsaddAll(ArraysasList(clazzgetDeclaredFields())); // 获取所有父类的字段, 父类中的字段需要逐级获取 Class clazzSuper = clazzgetSuperclass(); // 如果父类不是object,表明其继承的有其他类。 逐级获取所有父类的字段 while (clazzSuper != Objectclass) { allFieldsaddAll(ArraysasList(clazzSupergetDeclaredFields())); clazzSuper = clazzSupergetSuperclass(); } allFieldsstream()forEach(field -> { // 设置字段可访问, 否则无法访问private修饰的变量值 fieldsetAccessible(true); try { // 获取字段名称 String fieldName = fieldgetName(); // 获取指定对象的当前字段的值 Object fieldVal = fieldget(stu1); Systemoutprintln(fieldName+"="+fieldVal); } catch (IllegalAccessException e) { eprintStackTrace(); } }); } }
List 是一个集合 你得把他转换成你存时的类型
例如
for(int i=0;i<listsize();i++)
{
User users = (User)Listget(i);
}
这样就从List中取出来每个对象了 每个对象取出来 属性就出来了。
以上就是关于如何在java中用hql或sql查询得到某表的所有字段名全部的内容,包括:如何在java中用hql或sql查询得到某表的所有字段名、java查询某两个字段返回list列表,、java反射获取属性值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)