当前位置:编程学习 > JAVA >>

SSH如何获取数据库中的列名

SSH中如何获取数据库中某个表的列名并显示出来? --------------------编程问答--------------------
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("数据库连接失败"); 





楼主参考下吧,别人博客里的 --------------------编程问答-------------------- jdbc 楼上的是对的。
但ssh,确切的说应该是hibernate 要得到库的元数据,
1、意义不大,因为hibernate 底层就是利用jdbc封装查询的结果的。
2、还真不知道怎么得到。期待高人。
3、想问一下楼主想干什么? --------------------编程问答-------------------- 用ssh获取某个表中某一字段的值吧!
先获取那个表对应的类
再从类中得到你想要的列的值。 --------------------编程问答-------------------- 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();
...

大致是这个样子,你多看看书就会更清楚了。。。。
--------------------编程问答-------------------- 好好看看ResultSetMetaData 的使用。 --------------------编程问答-------------------- 难道在ssh中没办法查么? --------------------编程问答-------------------- 既然用了hibernate,就应该在hbm.xml配置文件中有设置,可以读取配置文件来查询,如果用了JPA的Annotation,这个就不是很清楚了,不清楚楼主的意图~~ --------------------编程问答-------------------- 谁能跟我说下ssh都有哪些用处啊 --------------------编程问答-------------------- 楼上,ssh 我理解就是MVC的应用框架已经给你设计完毕,你去应用就可以了,有想法可以自己改造一下 --------------------编程问答-------------------- 其实用反射。不需要去数据库中拿。拿实体的属性是一样的 --------------------编程问答--------------------

                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();
--------------------编程问答-------------------- 。。。hibernate是可以拿到滴,传送门过去

http://apps.hi.baidu.com/share/detail/7067426


--------------------编程问答--------------------
引用 5 楼 ivorytower 的回复:
好好看看ResultSetMetaData 的使用。

这个 --------------------编程问答-------------------- 建议是用jdbc   使用jdbc 的方式可以获取到一个List集合,List 集合里会存放map 结构,便利map 获取map 中的Key  就可以得到表的列名。个人猜想,仅供参考。
补充:Java ,  Java EE
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,