Java ResultSet findColumn()方法附带示例
当我们执行某些 SQL 查询(通常是 SELECT 查询)时,它们将返回表格数据。
java.sql.ResultSet 接口表示 SQL 语句返回的此类表格数据。
即,ResultSet 对象保存由用于查询数据库的语句执行方法(通常是 Statement 接口的 executeQuery() 方法)返回的表格数据。
ResultSet 对象有一个游标/指针,指向当前行。最初,此游标位于第一行的前一位。
ResultSet 接口的findColumn() 方法将列标签映射到列索引。使用此方法,你可以在结果集中查找特定列的索引。
此方法接受一个表示列标签的 String 变量,并返回一个表示给定列标签的列索引的整数值。
让我们使用 CREATE 语句在 MySQL 数据库中创建一个名为 MyPlayers 的表,如下所示:
CREATE TABLE MyPlayers( ID INT, First_Name VARCHAR(255), Last_Name VARCHAR(255), Date_Of_Birth date, Place_Of_Birth VARCHAR(255), Country VARCHAR(255), PRIMARY KEY (ID) );
现在,我们将在 MyPlayers 表中使用 INSERT 语句插入 7 条记录
insert into MyPlayers values(1, 'Shikhar', 'Dhawan', DATE('1981-12-05'), 'Delhi', 'India'); insert into MyPlayers values(2, 'Jonathan', 'Trott', DATE('1981-04-22'), 'CapeTown', 'SouthAfrica'); insert into MyPlayers values(3, 'Kumara', 'Sangakkara', DATE('1977-10-27'), 'Matale', 'Srilanka'); insert into MyPlayers values(4, 'Virat', 'Kohli', DATE('1988-11-05'), 'Delhi', 'India'); insert into MyPlayers values(5, 'Rohit', 'Sharma', DATE('1987-04-30'), 'Nagpur', 'India'); insert into MyPlayers values(6, 'Ravindra', 'Jadeja', DATE('1988-12-06'), 'Nagpur', 'India'); insert into MyPlayers values(7, 'James', 'Anderson', DATE('1982-06-30'), 'Burnley', 'England');
以下示例将 MyPlayers 表的内容作为 ResultSet 对象进行检索,并且检索 Date_Of_Birth 列的索引并显示该索引。
示例
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class ResultSet_findColumn { public static void main(String args[]) throws SQLException { //Registering the Driver DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //Getting the connection String mysqlUrl = "jdbc:mysql://127.0.0.1/mydatabase"; Connection con = DriverManager.getConnection(mysqlUrl, "root", "password"); System.out.println("Connection established......"); //Creating the Statement Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); //Query to retrieve records String query = "Select * from MyPlayers"; //Executing the query ResultSet rs = stmt.executeQuery(query); //Retrieving the index of a column int column_index = rs.findColumn("Date_Of_Birth"); System.out.println("Index of the coulmn named Date_Of_Birth is: "+column_index); } }
输出
Connection established...... Index of the column named Date_Of_Birth is: 4
广告