SSH中如何获取数据库中某个表的列名并显示出来?

解决方案 »

  1.   

    import java.sql.Connection; 
    import java.sql.DriverManager; 
    import java.sql.ResultSet; 
    import java.sql.PreparedStatement; 
    import java.sql.ResultSetMetaData; 
    import java.sql.SQLException; public class TestDemo { 
    public static Connection getConnection(){ 
    Connection conn = null; 
    try { 
    Class.forName("com.mysql.jdbc.Driver"); 
    String url = "jdbc:mysql://localhost:3306/test"; 
    String user = "root"; 
    String pass = "123456"; 
    conn = DriverManager.getConnection(url,user,pass); 
    } catch (ClassNotFoundException e) { 
    e.printStackTrace(); 
    } catch (SQLException e) { 
    e.printStackTrace(); 

    return conn; 

    public static void main(String[] args){ 
    Connection conn=getConnection(); 
    String sql="select * from users"; 
    PreparedStatement stmt; 
    try { 
    stmt = conn.prepareStatement(sql); 
    ResultSet rs=stmt.executeQuery(sql); 
    ResultSetMetaData data=rs.getMetaData(); 
    while(rs.next()){ 
    for(int i = 1 ; i<= data.getColumnCount() ; i++){ 
    //获得所有列的数目及实际列数 
    int columnCount=data.getColumnCount(); 
    //获得指定列的列名 
    String columnName = data.getColumnName(i); 
    //获得指定列的列值 
    String columnValue = rs.getString(i); 
    //获得指定列的数据类型 
    int columnType=data.getColumnType(i); 
    //获得指定列的数据类型名 
    String columnTypeName=data.getColumnTypeName(i); 
    //所在的Catalog名字 
    String catalogName=data.getCatalogName(i); 
    //对应数据类型的类 
    String columnClassName=data.getColumnClassName(i); 
    //在数据库中类型的最大字符个数 
    int columnDisplaySize=data.getColumnDisplaySize(i); 
    //默认的列的标题 
    String columnLabel=data.getColumnLabel(i); 
    //获得列的模式 
    String schemaName=data.getSchemaName(i); 
    //某列类型的精确度(类型的长度) 
    int precision= data.getPrecision(i); 
    //小数点后的位数 
    int scale=data.getScale(i); 
    //获取某列对应的表名 
    String tableName=data.getTableName(i); 
    // 是否自动递增 
    boolean isAutoInctement=data.isAutoIncrement(i); 
    //在数据库中是否为货币型 
    boolean isCurrency=data.isCurrency(i); 
    //是否为空 
    int isNullable=data.isNullable(i); 
    //是否为只读 
    boolean isReadOnly=data.isReadOnly(i); 
    //能否出现在where中 
    boolean isSearchable=data.isSearchable(i); 
    System.out.println(columnCount); 
    System.out.println("获得列"+i+"的字段名称:"+columnName); 
    System.out.println("获得列"+i+"的字段值:"+columnValue); 
    System.out.println("获得列"+i+"的类型,返回SqlType中的编号:"+columnType); 
    System.out.println("获得列"+i+"的数据类型名:"+columnTypeName); 
    System.out.println("获得列"+i+"所在的Catalog名字:"+catalogName); 
        System.out.println("获得列"+i+"对应数据类型的类:"+columnClassName); 
        System.out.println("获得列"+i+"在数据库中类型的最大字符个数:"+columnDisplaySize); 
        System.out.println("获得列"+i+"的默认的列的标题:"+columnLabel); 
        System.out.println("获得列"+i+"的模式:"+schemaName); 
        System.out.println("获得列"+i+"类型的精确度(类型的长度):"+precision); 
        System.out.println("获得列"+i+"小数点后的位数:"+scale); 
        System.out.println("获得列"+i+"对应的表名:" + tableName); 
        System.out.println("获得列"+i+"是否自动递增:"+isAutoInctement); 
        System.out.println("获得列"+i+"在数据库中是否为货币型:"+isCurrency); 
        System.out.println("获得列"+i+"是否为空:"+isNullable); 
        System.out.println("获得列"+i+"是否为只读:"+isReadOnly); 
        System.out.println("获得列"+i+"能否出现在where中:"+isSearchable);  


    } catch (SQLException e) { 
    System.out.println("数据库连接失败"); 



    楼主参考下吧,别人博客里的
      

  2.   

    jdbc 楼上的是对的。
    但ssh,确切的说应该是hibernate 要得到库的元数据,
    1、意义不大,因为hibernate 底层就是利用jdbc封装查询的结果的。
    2、还真不知道怎么得到。期待高人。
    3、想问一下楼主想干什么?
      

  3.   

    用ssh获取某个表中某一字段的值吧!
    先获取那个表对应的类
    再从类中得到你想要的列的值。
      

  4.   

    hibernate可以实现连接查询数据库
    你可以根据数据库逆向生成hibernate
    ,然后例如:数据库User表会对应一个User类
    通过UserDAO中的方法去查询,
    我们距离查询User表中的ID="123"的这个用户实例
    再然后通过get方法获取实例中的属性值String id = "123";
    User user = new User();
    UserDAO dao = new UserDAO();
    user = (User)UserDAO.fingById(id);
    String name = (String)user.getName();
    ...大致是这个样子,你多看看书就会更清楚了。
      

  5.   

    好好看看ResultSetMetaData 的使用。
      

  6.   

    既然用了hibernate,就应该在hbm.xml配置文件中有设置,可以读取配置文件来查询,如果用了JPA的Annotation,这个就不是很清楚了,不清楚楼主的意图~~
      

  7.   

    谁能跟我说下ssh都有哪些用处啊
      

  8.   

    楼上,ssh 我理解就是MVC的应用框架已经给你设计完毕,你去应用就可以了,有想法可以自己改造一下
      

  9.   


                    Class.forName("com.mysql.jdbc.Driver");
    Connection con = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test","root","76554792");
    Statement st = con.createStatement();
    ResultSet rs = st.executeQuery("select * from classes");
    ResultSetMetaData rsmd = rs.getMetaData();
    for(int i = 1;i < rsmd.getColumnCount();i++)
    {
    System.out.println(rsmd.getColumnName(i)+":"+rsmd.getColumnTypeName(i));
    }
    rs.close();
    con.close();
      

  10.   

    hibernate是可以拿到滴,传送门过去http://apps.hi.baidu.com/share/detail/7067426
      

  11.   

    建议是用jdbc   使用jdbc 的方式可以获取到一个List集合,List 集合里会存放map 结构,便利map 获取map 中的Key  就可以得到表的列名。个人猜想,仅供参考。