Java获取数据库的表中各字段的字段名等相关信息-很详细
2015-08-31 13:05
585 查看
最近需要获取数据库中的字段相关信息,在此整理,以备后用(我感觉可以把这些常用的 方法等,封装起来,以后用着就比较方便了)
Java获取数据库的表中各字段的字段名,代码如下:
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://数据库IP地址:3306/数据库名称"; String user = "数据库用户名"; String pass = "数据库用户密码"; 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 AccessType"; PreparedStatement stmt; try { stmt = conn.prepareStatement(sql); ResultSet rs = stmt.executeQuery(sql); ResultSetMetaData data = rs.getMetaData(); for (int i = 1; i <= data.getColumnCount(); i++) { // 获得所有列的数目及实际列数 int columnCount = data.getColumnCount(); // 获得指定列的列名 String columnName = data.getColumnName(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 + "的类型,返回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) { e.printStackTrace(); } } }
相关文章推荐
- Spring中Quartz调度器的使用 ----继承QuartzJobBean,不继承QuartzJobBean两种方式
- Spring MVC Controller 多方法
- Spring+Quartz实现定时任务的配置方法--Cron表达式解释
- [leetcode-273]Integer to English Words(java)
- java内存回收机制
- 利用javadoc生成API文档
- java项目转成WEB项目快捷方法
- Struts2+Spring+Ibatis集成合并
- 【spring框架】(三)面向切面编程(AOP)
- 关于在Spring配置文件中解决MySQL重连问题
- microsoft docx document operation with Java POI library
- 深入理解Java:SimpleDateFormat安全的时间格式化
- Java程序台写的五子棋
- 深入理解Java内存模型
- Spring依赖注入
- Spring笔记——依赖注入
- eclipse安装EXT JS插件
- Lucene-Java全文搜索引擎
- Java中JDBC的基本步骤
- java判断数据类型两种方式