DatabaseMetaData 有关整个数据库的信息:表名、表的索引、数据库产品的名称和版本、数据库支持的操作。
ResultSet 关于某个表的信息或一个查询的结果。您必须逐行访问数据行,但是您可以任何顺序访问列。
ResultSetMetaData 有关 ResultSet 中列的名称和类型的信息。
尽管每个对象都有大量的方法让您获得数据库元素的极为详细的信息,但在每个对象中都有几种主要的方法使您可获得数据的最重要信息。然而,如果您希望看到比此处更多的信息,建议您学习文档以获得其余方法的说明。
ResultSet
ResultSet 对象是 JDBC 中最重要的单个对象。从本质上讲,它是对一个一般宽度和未知长度的表的一种抽象。几乎所有的方法和查询都将数据作为 ResultSet 返回。ResultSet 包含任意数量的命名列,您可以按名称访问这些列。它还包含一个或多个行,您可以按顺序自上而下逐一访问。在您使用 ResultSet 之前,必须查询它包含多少个列。此信息存储在 ResultSetMetaData 对象中。
//从元数据中获得列数
ResultSetMetaData rsmd;
rsmd = results.getMetaData();
numCols = rsmd.getColumnCount();
当您获得一个 ResultSet 时,它正好指向第一行之前的位置。您可以使用 next() 方法得到其他每一行,当没有更多行时,该方法会返回 false。由于从数据库中获取数据可能会导致错误,您必须始终将结果集处理语句包括在一个 try 块中。
您可以多种形式获取 ResultSet 中的数据,这取决于每个列中存储的数据类型。另外,您可以按列序号或列名获取列的内容。请注意,列序号从 1 开始,而不是从 0 开始。ResultSet 对象的一些最常用方法如下所示。
getInt(int); 将序号为 int 的列的内容作为整数返回。
getInt(String); 将名称为 String 的列的内容作为整数返回。
getFloat(int); 将序号为 int 的列的内容作为一个 float 型数返回。
getFloat(String); 将名称为 String 的列的内容作为 float 型数返回。
getDate(int); 将序号为 int 的列的内容作为日期返回。
getDate(String); 将名称为 String 的列的内容作为日期返回。
next(); 将行指针移到下一行。如果没有剩余行,则返回 false。
Close(); 关闭结果集。
getMetaData(); 返回 ResultSetMetaData 对象。
ResultSetMetaData
您使用 getMetaData() 方法从 ResultSet 中获取 ResultSetMetaData 对象。您可以使用此对象获得列的数目和类型以及每一列的名称。
getColumnCount(); 返回 ResultSet 中的列数。
getColumnName(int); 返回列序号为 int 的列名。
getColumnLabel(int); 返回此列暗含的标签。
isCurrency(int); 如果此列包含带有货币单位的一个数字,则返回 true。
isReadOnly(int); 如果此列为只读,则返回 true。
isAutoIncrement(int); 如果此列自动递增,则返回 true。这类列通常为键,而且始终是只读的。
getColumnType(int); 返回此列的 SQL 数据类型。这些数据类型包括
BIGINT
BINARY
BIT
CHAR
DATE
DECIMAL
DOUBLE
FLOAT
INTEGER
LONGVARBINARY
LONGVARCHAR
NULL
NUMERIC
OTHER
REAL
SMALLINT
TIME
TIMESTAMP
TINYINT
VARBINARY
VARCHAR
DatabaseMetaData
DatabaseMetaData 对象可为您提供整个数据库的信息。您主要用它获取数据库中表的名称,以及表中列的名称。由于不同的数据库支持不同的 SQL 变体,因此,也有多种方法查询数据库支持哪些 SQL 方法。
getCatalogs() 返回该数据库中的信息目录列表。使用 JDBC-ODBC Bridge 驱动程序,您可以获得用 ODBC 注册的数据库列表。这很少用于 JDBC-ODBC 数据库。
getTables(catalog, schema,tableNames, columnNames) 返回表名与 tableNames 相符而且列名与 columnNames 相符的所有表的说明。
getColumns(catalog, schema,tableNames, columnNames) 返回表名与 tableNames 相符而且列名与 columnNames 相符的所有表列说明。
getURL(); 获得您所连接的 URL 名称。
getDriverName(); 获得您所连接的数据库驱动程序的名称。
获取有关表的信息
您可以使用 DataBaseMetaData 的 getTables() 方法来获取数据库中表的信息。这个方法有如下4个 String 参数:
results =dma.getTables(catalog, schema, tablemask, types[]);
其中参数的意义是:
Catalog 要在其中查找表名的目录名。对于 JDBC-ODBC 数据库以及许多其他数据库而言,可将其设置为 null。这些数据库的目录项实际上是它在文件系统中的绝对路径名称。
Schema 要包括的数据库“方案”。许多数据库不支持方案,而对另一些数据库而言,它代表数据库所有者的用户名。一般将它设置为 null。
Tablemask 一个掩码,用来描述您要检索的表的名称。如果您希望检索所有表名,则将其设为通配符 %。请注意,SQL 中的通配符是 % 符号,而不是一般 PC 用户的 * 符号。
types[] 这是描述您要检索的表的类型的 String 数组。数据库中通常包括许多用于内部处理的表,而对作为用户的您没什么价值。如果它是空值,则您会得到所有这些表。如果您将其设为包含字符串“TABLES”的单元素数组,您将仅获得对用户有用的表格。
一个简单的 JDBC 程序
我们已经学习了 JDBC 的所有基本功能,现在我们可以编写一个简单的程序,该程序打开数据库,打印它的表名以及某一表列的内容,然后对该数据库执行查询。此程序如下所示:
package skydevkit;
import java.sql.*;
public class JdbcOdbc_test {
ResultSet results;
ResultSetMetaData rsmd;
DatabaseMetaData dma;
Connection con;
public JdbcOdbc_test() throws SQLException {
String url = "jdbc:odbc:Northwind";
try {
//加载 JDBC-ODBC 桥驱动程序
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
con = DriverManager.getConnection(url);//连接数据库
dma = con.getMetaData();//获取数据库的元数据
System.out.println("Connected to:" + dma.getURL());
System.out.println("Driver " + dma.getDriverName());
} catch (Exception e) {
System.out.println(e);
}
try {
Statement stmt = con.createStatement();
results = stmt.executeQuery("select * from 客户;");
ResultSetMetaData resultMetaData = results.getMetaData();
int cols = resultMetaData.getColumnCount();
String resultRow = "";
for (int i = 1; i < cols; i++) {
resultRow += resultMetaData.getColumnName(i) + ";";
}
System.out.println(resultRow);
while (results.next()) {
resultRow = "";
for (int i = 1; i < cols; i++) {
try {
resultRow += results.getString(i) + ";";
} catch (NullPointerException e) {
System.out.println(e.getMessage());
}
}
System.out.println(resultRow);
}
} catch (Exception e) {
System.out.println("query exception");
} finally {
results.close();
}
}
}
补充高级内容
关于调用SQLServer存储过程的例子:(用到了我们开发的数据库连接类)
CREATE PROCEDURE [dbo].[sp_getStudentByName](@name char(10))
AS
Select * from Students where [Name]=@name
GO
DbObject DbO = new DbObject(new SqlServerConnectionFactory("localhost",
1433, "demo", "sa", ""));
Connection con = DbO.getConnection();
CallableStatement pstmt = null;
System.out.println("TestDB1()............");
/* try {
pstmt = con.prepareCall("{call sp_getStudentById(?)}");
pstmt.setInt(1, 1);
}*/
try {
pstmt = con.prepareCall("{call sp_getStudentByName(?)}"); //注意参数如何传递
pstmt.setString(1, "Tom");
}
……
使用输出参数:
CREATE PROCEDURE [dbo].[sp_insertStudent](@name char(10),@age int,@id int OUTPUT) AS
insert into Students([Name],[Age]) values (@name,@age)
select @id=@@IDENTITY
GO
try {
pstmt = con.prepareCall("{call sp_insertStudent(?,?,?)}");
pstmt.setString(1, "zengqingsong");
pstmt.setInt(2, 22);
pstmt.registerOutParameter(3, Types.INTEGER);
pstmt.executeUpdate();
int id = pstmt.getInt(3);
System.out.println(id);
}
使用返回参数的例子:
CREATE PROCEDURE [dbo].[sp_insertStudent](@name char(10),@age int,@id int OUTPUT) AS
insert into Students([Name],[Age]) values (@name,@age)
select @id=@@IDENTITY –测试输出参数
return 30 –测试返回30
GO
try {
pstmt = con.prepareCall("{?=call sp_insertStudent(?,?,?)}");
pstmt.setString(2, "zengqingsong");
pstmt.setInt(3, 22);
pstmt.registerOutParameter(4, Types.INTEGER);
pstmt.registerOutParameter(1, Types.INTEGER);
int ret = pstmt.executeUpdate(); //执行影响的行数
int ret2 = pstmt.getInt(1); //返回参数(输出参数)
int id = pstmt.getInt(4); //输出参数
System.out.println(ret);
System.out.println(ret2);
System.out.println(id);
- 浏览: 83557 次
最新评论
-
letmedown:
使用AOP是不是比这个更简单一些呢?
Java项目如何记录日志
相关推荐
- **`ResultSetMetaData`** 和 **`DatabaseMetaData`** - 分别提供关于结果集和数据库的整体元数据信息。 2. **`javax.sql`** - 提供更高级的数据库操作功能。 - **`DataSource`** - 用于管理数据库连接池。 - *...
5. `getColumnTypeName(int column)`:返回列的数据库特定的类型名称,这个信息可能更详细,包含数据库特有的类型信息。 6. `getPrecision(int column)` 和 `getScale(int column)`:分别提供列的精度和小数位数,...
9. **ResultSetMetaData**:提供关于结果集列的信息。 10. **Types**:定义SQL数据类型的常量。 **JDBC 2.0及以后的增强特性:** 1. **数据源(DataSource)**:采用工厂模式,通过DataSource对象创建连接,简化了...
以下是对给定示例代码的详细解释: 1. **加载驱动程序**: ```java String driver = "com.mysql.jdbc.Driver"; Class.forName(driver); ``` 这里首先指定了MySQL的JDBC驱动程序类名,并使用`Class.forName()`...
下面我们将详细探讨如何使用Java API 来操作 Druid。\n\n**一、需求与实现步骤**\n\n在本示例中,我们的目标是查询 Druid 数据源中的 `testdata` 表中的所有数据。这通常涉及到以下步骤:\n\n1. **导入依赖**:首先...
### 关于JDBC的详细介绍 #### 一、JDBC概览 JDBC(Java Database Connectivity)是一种用于执行SQL语句的Java API,它可以为多种关系型数据库提供统一访问,简化了Java开发人员对数据库的操作。从物理结构上看,...
开发者可以通过ResultSetMetaData获取列的详细信息,方便在程序中动态处理结果集。 6. **配置对象的属性**:在使用JDBC驱动和数据库连接池时,通常需要配置一些属性,如数据库URL、用户名、密码、连接池的最大/最小...
以下将详细讲解标题和描述中提及的一些关键知识点。 1. **dbutils**: Apache Commons DbUtils 是一个轻量级Java库,它简化了JDBC(Java Database Connectivity)的常用任务,如打开和关闭数据库连接、处理结果集等...
- 元数据:提供了ResultSetMetaData、DatabaseMetaData、ParameterMetaData的使用信息。 - RowSet:介绍了CachedRowSet和JdbcRowSet的使用。 - 分布式事务支持:讲述了如何使用XA数据源、XA连接和XAResource来管理...
- 例如,可以通过`ResultSetMetaData.getColumnCount()`获取列的数量,通过`ResultSetMetaData.getColumnName(int column)`获取指定列的名称。 5. **示例代码:** ```java ResultSet rs = stmt.executeQuery(...
本文将详细介绍如何利用`JScrollPane`、`JTable`、`Vector`、`AbstractTableModel`以及`ResultSetMetaData`等组件和技术,将数据库中的表内容显示到窗口中。 #### 一、导入必要的包 首先,我们需要导入以下包: `...
下面将详细介绍如何使用这个 API 进行查询。 标量查询(Scalar queries) ------------------------- 最基本的 SQL 查询就是获得一个标量(数值)的列表。使用 sess.createSQLQuery("SELECT * FROM CATS").list();...
3. **获取元数据**:通过`ResultSetMetaData`对象来获取查询结果集的元数据,包括列名和列类型。 4. **封装结果**:将获取到的列名和列类型存储到一个`Map`中返回。 #### 二、详细步骤与代码实现 ##### 1. 加载...
下面将详细阐述如何利用JDBC操纵数据库,以及涉及的相关类和方法。 1. **数据库连接** - **加载驱动程序**:在Java中,我们通常通过`Class.forName("com.mysql.jdbc.Driver")`这样的语句来加载数据库驱动。这里的...
3. **ResultSetMetaData**:当使用Statement或PreparedStatement执行查询并获取ResultSet时,ResultSetMetaData对象可以提供关于结果集列的信息,如列数、列名、列数据类型等。在管理系统中,这有助于我们更好地理解...
本文将详细介绍如何使用`ResultSet`对象来获取数据,并通过实例解释各种方法的具体应用。 #### 1. ResultSetMetaDatarsmd = rs.getMetaData(); `ResultSetMetaData`接口提供了有关`ResultSet`对象的信息,包括列的...
7. 元数据接口:java.sql.DatabaseMetaData、java.sql.ResultSetMetaData 四、Spring Boot整合 Spring Boot提供了对JDBC的支持,使得开发者可以轻松地与数据库集成。在Spring Boot中,我们可以使用Spring JDBC模块...
下面我们将详细介绍Java中Boolean与字符串或者数字1和0的转换实例。 一、Boolean类型与bit类型字段的映射 在Java中,Boolean类型字段可以与数据库中的bit类型字段进行映射。bit类型字段通常用于存储布尔值,只存储...
本文将详细解析如何实现这个过程,包括链接数据库、执行查询、接收结果以及将数据添加到二维数组。 首先,我们需要链接到数据库。在给定的代码中,使用的是JDBC-ODBC桥接驱动来连接数据库。`JproManDB`类中定义了一...