Java DatabaseMetaData getColumns()方法与示例
此方法检索表的列的描述。它接受4个参数-
catalog-目录-一个字符串参数,表示表(包含通常需要检索其描述的列的表)的目录(通常是数据库)的名称(或名称模式)。传递“”以获取没有目录的表中列的描述,如果不想使用目录,则传递null,从而缩小搜索范围。
schemaPattern-一个String参数,表示表的架构的名称(或名称模式),如果表中的列没有架构,则传递“”,如果您不想使用架构,则传递null。
tableNamePattern-一个String参数,代表表的名称(或名称模式)。
columnNamePattern-一个String参数,表示列的名称(或名称模式)。
此方法返回描述指定列的ResultSet对象。该对象保存以下详细信息的值(作为列名)-
获取数据库中所需列的描述-
确保您的数据库已启动并正在运行。
使用registerDriver()
DriverManager类的方法注册驱动程序。传递与基础数据库相对应的驱动程序类的对象。
使用getConnection()
DriverManager类的方法获取连接对象。将URL和数据库中的用户密码作为字符串变量传递给数据库。
使用getMetaData()
Connection接口的方法获取有关当前连接的DatabaseMetaData对象。
最后,通过调用getColumns()
DatabaseMetaData接口的方法,获取包含所需列的描述的ResultSet对象。
示例
让我们创建一个名称为example_database的数据库,并使用CREATE语句在其中创建一个名称为sample_table的表,如下所示-
Statement stmt = con.createStatement(); stmt.execute("CREATE DATABASE example_database"); stmt.execute("CREATE TABLE example_database.sample_table(Name VARCHAR(255), age INT, Location VARCHAR(255));");
现在,在此表中,我们将插入两个记录-
stmt.execute("INSERT INTO example_database.sample_table values('Kasyap', 29, 'Vishakhapatnam')"); stmt.execute("INSERT INTO example_database.sample_table values('Krishna', 30, 'Hyderabad')");
下面的JDBC程序建立与MySQL数据库的连接,检索指定列的描述。
import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; public class DatabaseMetaData_getColumns { public static void main(String args[]) throws SQLException { //注册驱动程序 DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //获得连接 String url = "jdbc:mysql://localhost/example_database"; Connection con = DriverManager.getConnection(url, "root", "password"); System.out.println("Connection established......"); //检索元数据对象 DatabaseMetaData metaData = con.getMetaData(); //检索数据库中的列 ResultSet columns = metaData.getColumns(null, null, "sample_table", null); //打印列名称和大小 while (columns.next()){ System.out.print("Column name and size: "+columns.getString("COLUMN_NAME")); System.out.print("("+columns.getInt("COLUMN_SIZE")+")"); System.out.println(" "); System.out.println("Ordinal position: "+columns.getInt("ORDINAL_POSITION")); System.out.println("Catalog: "+columns.getString("TABLE_CAT")); System.out.println("Data type (integer value): "+columns.getInt("DATA_TYPE")); System.out.println("Data type name: "+columns.getString("TYPE_NAME")); System.out.println(" "); } } }
输出结果
Connection established...... Column name and size: Name(255) Ordinal position: 1 Catalog: example_database Data type (integer value): 12 Data type name: VARCHAR Column name and size: age(10) Ordinal position: 2 Catalog: example_database Data type (integer value): 4 Data type name: INT Column name and size: Location(255) Ordinal position: 3 Catalog: example_database Data type (integer value): 12 Data type name: VARCHAR