如何在java中用hql或sql查询得到某表的所有字段名

如何在java中用hql或sql查询得到某表的所有字段名,第1张

那就得看用的是什么数据库了,比如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反射获取属性值是怎样的呢?一起来看下吧:

反射获取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反射获取属性值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9724426.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存