转自博客:http://blog.csdn.net/ocean1010/article/details/7266042
假设有个con
DatabaseMetaData dbmd = con.getMetaData();
rs = dbmd.getColumns(con.getCatalog(), schema, tableName, null);
rs.getString(DATA_TYPE) java.sql.Types 的 SQL 类型
rs.getString(COLUMN_SIZE) 列的大小。对于 char 或 date 类型,列的大小是最大字符数,对于 numeric 和 decimal 类型,列的大小就是精度。
rs.getString(DECIMAL_DIGITS) 小数部分的位数
JDBC中通过MetaData来获取具体的表的相关信息。可以查询数据库中的有哪些表,表有哪些字段,字段的属性等等。MetaData中通过一系列getXXX函数,将这些信息存放到ResultSet里面,然后返回给用户。关于MetaData的说明网上也有不少,这里我只是从我自身学习的角度来记录一下简单使用JDBC以及获取数据表相关信息的方法。
首先,http://hometown.aol.com/kgb1001001/Articles/JDBCMetadata/JDBC_Metadata.htm 这里有篇名字叫做《Understanding JDBC MetaData》的文章,讲解得不错。
下面就是我的JDBC下的获取表信息的代码了。我是以MySQL 5.0作为测试平台的。
1. JDBC连接MYSQL的代码很标准,很简单。
class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conn = DriverManager
.getConnection("jdbc:mysql://localhost/test?user=root&password=123456");
2. 下面就是获取表的信息。
m_DBMetaData = m_Connection.getMetaData();
ResultSet tableRet = m_DBMetaData.getTables(null, "%",m_TableName,new String[]{"TABLE"});
其中"%"就是表示*的意思,也就是任意所有的意思。其中m_TableName就是要获取的数据表的名字,如果想获取所有的表的名字,就可以使用"%"来作为参数了。
3. 提取表的名字。
while(tableRet.next) System.out.println(tableRet.getString("TABLE_NAME"));
通过getString("TABLE_NAME"),就可以获取表的名字了。
从这里可以看出,前面通过getTables的接口的返回,JDBC是将其所有的结果,保存在一个类似table的内存结构中,而其中TABLE_NAME这个名字的字段就是每个表的名字。
4. 提取表内的字段的名字和类型
String columnName;
String columnType;
ResultSet colRet = m_DBMetaData.getColumns(null,"%", m_TableName,"%");
while(colRet.next()) {
columnName = colRet.getString("COLUMN_NAME");
columnType = colRet.getString("TYPE_NAME");
int datasize = colRet.getInt("COLUMN_SIZE");
int digits = colRet.getInt("DECIMAL_DIGITS");
int nullable = colRet.getInt("NULLABLE");
System.out.println(columnName+" "+columnType+" "+datasize+" "+digits+" "+
nullable);
}
JDBC里面通过getColumns的接口,实现对字段的查询。跟getTables一样,"%"表示所有任意的(字段),而m_TableName就是数据表的名字。
getColumns的返回也是将所有的字段放到一个类似的内存中的表,而COLUMN_NAME就是字段的名字,TYPE_NAME就是数据类型,比如"int","int unsigned"等等,COLUMN_SIZE返回整数,就是字段的长度,比如定义的int(8)的字段,返回就是8,最后NULLABLE,返回1就表示可以是Null,而0就表示Not Null。
-------------------
大多数数据库有许多主键,但是在一个表中不允许两条记录的同一个主键具有相同的值。可以使用Java Database Connectivity(JDBC)来判断一个数据表的主键。
JDBC具有强大的元数据处理能力。java.sql.Connection类和java.sql.ResultSet类可以通过调用其getMetaData方法进行反射,例如:
// 对java.sql中所有的类
Connection connection = .....
DatabaseMetaData dbMeta = connection.getMetaData();
ResultSet rset = .....
ResultSetMetaData rsMeta = rset.getMetaData();
java.sql.DatabaseMetaData类包含一个查找数据表主键的方法。你需要知道表的名字,catalog名和schema名。如果不知道catalog和schema,那么你可以不使用它们而输入“null”。例如:
// 查找一个名字为“Comment”的表的主键
// 没有catalog或schema,都设置为null
ResultSet pkRSet = dbMeta.getPrimaryKeys(null, null, "Comment");
while( pkRSet.next() ) {
System.err.println("****** Comment ******");
System.err.println("TABLE_CAT : "+pkRSet.getObject(1));
System.err.println("TABLE_SCHEM: "+pkRSet.getObject(2));
System.err.println("TABLE_NAME : "+pkRSet.getObject(3));
System.err.println("COLUMN_NAME: "+pkRSet.getObject(4));
System.err.println("KEY_SEQ : "+pkRSet.getObject(5));
System.err.println("PK_NAME : "+pkRSet.getObject(6));
System.err.println("****** ******* ******");
}
在这个例子中表“Comment”具有一个叫做“comment_id”的主键。
下面是上面这些代码在MySQL上的输出:
****** Comment ******
TABLE_CAT :
TABLE_SCHEM:
TABLE_NAME : Comment
COLUMN_NAME: column_id
KEY_SEQ : 1
PK_NAME : column_id
****** ******* ******
存在PK_NAME的原因是有时会为一个主键使用列名之外的名字。而KEY_SEQ表示了主键的顺序位置。有些使用字母顺序保存主键的数据库会为KEY_SEQ返回0。
当创建通用的数据库应用时,查找一个表的主键是很基本的。JDBC的MetaData类提供了所需的数据库反射机制,从而使得这些应用的实现成为可能。
相关推荐
在Java编程中,读取MySQL数据库的表结构是一项常见的任务,尤其在开发数据管理或数据分析应用时。这个过程涉及到连接数据库、执行SQL查询以及解析返回的结果集。下面将详细讲解如何实现这一功能。 首先,我们需要...
OSWorkflow基于JDBC(oracle)存储实现的表结构 OSWorkflow基于JDBC(oracle)存储实现的表结构是指使用Oracle数据库存储OSWorkflow工作流引擎的表结构设计。该设计主要包括两个表:OS_WFENTRY和OS_CURRENTSTEP。 OS_...
2. SQL查询:为了获取表结构信息,程序可能会执行SQL命令,如`DESCRIBE`或`SHOW COLUMNS`,来获取表的列名、数据类型、主键等信息。 3. Excel文件生成:程序需要能够创建和写入Excel文件,这可能使用了诸如Apache ...
首先,我们要理解数据库表结构的基本元素,包括表名、字段(列)、数据类型、主键、外键、索引、约束条件等。对比表结构差异时,我们需要关注这些方面的相同与不同。例如,字段的数量、顺序、数据类型是否一致,以及...
例如,Java的JDBC接口允许开发者编写代码来查询数据库元数据,获取表结构。 在实际工作中,理解表结构对于以下任务至关重要: - **数据迁移**:当需要将数据从一个数据库迁移到另一个数据库时,了解源数据库的表...
在SQL中,表结构包括字段(列)定义、数据类型、主键约束等。要导出SQL数据库的表结构,可以使用多种方法,如使用数据库的内置工具或第三方软件。例如,在MySQL中,可以使用`SHOW CREATE TABLE`命令查看表的创建语句...
其表结构包括字段(列)、数据类型、主键、外键等元素,这些都需要在Word文档中详细记录以便于理解。 Oracle数据库则是由甲骨文公司提供的一个大型企业级数据库管理系统,支持各种数据类型和高级功能,如分布式...
在关系型数据库中,表结构包含了数据库表的详细信息,如表名、字段名、字段类型、长度、是否为主键、是否允许为空等。这些元数据对于理解数据的逻辑结构至关重要。通过将表结构导出到Excel,我们可以更直观地查看...
自己写的一个JDBC通用DAO ...因为没有用xml来映射表结构确定哪一个为该表的主键(因为一对多的情况下会有2个ID),所以id取名遵循 RUBY ON RAILS 的原则 "约定大于配置" 下一个版本会支持数据库表字段_写法:user_id
数据库表结构文档自动生成工具是一种高效实用的软件开发辅助工具,尤其在大型项目中,能够极大地提高数据库管理和维护的效率。这款工具采用Java语言编写,具备广泛的数据库兼容性,能够支持包括但不限于MySQL、...
同时,确保在迁移过程中正确处理主键和外键约束,避免数据不一致。 在实际操作中,可能还会遇到如字符集转换、数据类型不匹配等问题。例如,MySQL的字符集设置可能在源数据库和目标数据库中不同,这需要在迁移前...
它可以根据数据库表结构自动构建INSERT语句,并且支持返回新生成的主键值,这对于那些具有自动增长主键的表非常有用。 此外,Spring JDBC的`JdbcOperations`接口扩展了`JdbcTemplate`,提供了一组通用的JDBC操作,...
项目中使用的两个表的SQL文件用于创建数据库表结构,可能包括用户信息表和权限表等,用于存储和管理用户数据。 3. **用户登录与注册**:这是项目的基础功能,涉及对用户账户信息的验证和创建。在实现过程中,需要...
SQL脚本可能包括定义表结构的命令,如列名、数据类型、主键等。这通常是数据库设计的基础,为JDBC示例提供操作的数据对象。 2. **jdbc-demo** - 这个文件可能是一个Java源代码文件,实现了JDBC操作。它可能包含了...
本压缩包文件“读取mysql数据库表结构.7z”显然包含与从MySQL数据库获取表结构相关的资源。这里我们将深入探讨如何读取MySQL数据库的表结构以及其背后涉及的关键知识点。 1. **MySQL数据库基础**: - MySQL是开源...
本工具,名为"基于Java的简单数据库设计生成工具(生成Excel文档)",旨在简化这一过程,将数据库表结构、主键信息和索引信息等重要数据以直观易读的Excel格式呈现。 首先,让我们来了解下核心技术: 1. **Java**:...
在用户观点下,关系模型中数据的逻辑结构是一张二维表,它由行和列组成。记录(元组)是表中的 一行,即一条记录。属性是表中的 一列,即一个属性,给每一个属性起一个名称即属性名。主键(主码)是表中的某个属性组...
1. **数据库表结构**:数据库表结构是指数据库中各个表的字段定义,包括字段名、数据类型、长度、是否可为空、默认值、主键约束等。理解表结构是进行数据库设计和操作的基础。 2. **ORACLE数据库**:ORACLE是全球...
"读取数据库表结构生成自定义代码"这个主题涉及到数据库管理、数据建模以及自动化编程等多个方面。下面将详细探讨这些知识点。 首先,数据库表结构是数据库设计的重要组成部分,它定义了数据库中的表、字段(或称为...