0

我创建了一个程序来使用 rt 从用户 rt 获取所有表名DatabaseMetaData,尽管该程序已成功编译并且运行它并没有获取表名。它运行并显示表列表:然后没有名称。程序退出。

这里的任何人都可以帮助我在我的程序中找到错误的逻辑。

//DataBaseMetaDataTest
import java.sql.*;
class DatabaseMetaDataTest
{
    public static void main(String s[])
    {
        try
        {
            Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","rt","pwdd");
            DatabaseMetaData dbmd=con.getMetaData();
            ResultSet rs=dbmd.getTables(null,"rt",null,new String[]{"Table"});
            System.out.println("list of tables:");
            while(rs.next())
            {
                System.out.println(rs.getString(3));
            }
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
    }
}
4

1 回答 1

0

在 Oracle 中,模式 (=user) 名称以大写形式存储,因此您还需要在 JDBC 调用中以大写形式传递模式名称。

我认为您还需要以大写形式传递类型列表。

dbmd.getTables(null,"RT",null,new String[]{"TABLE"});
于 2016-07-18T13:08:53.257 回答