当前位置:  技术问答>java相关

请问JDBC连接中如何判断一个表是否存在呀?你开个价

    来源: 互联网  发布时间:2015-04-23

    本文导语:  String DRIVER= "com.borland.datastore.jdbc.DataStoreDriver"; Class.forName(DRIVER); connect=DriverManager.getConnection(URL,"饿饿额",""); 我这样建立了一个连接,我想判断某个表是否存在, 该怎么办呀?小弟是新人,请不吝赐教 |...

String DRIVER= "com.borland.datastore.jdbc.DataStoreDriver";
Class.forName(DRIVER);
connect=DriverManager.getConnection(URL,"饿饿额","");
我这样建立了一个连接,我想判断某个表是否存在,
该怎么办呀?小弟是新人,请不吝赐教

|
获得表中的信息
你可对DataBaseMetaData对象使用getTables()方法以得到数据库中表的信息。这
个方法有以下四个字符串参数: 

results = dma.getTables(catalog, schema, tablemask, types[]);

参数的意义为: 

catalog
 用来寻找表名的目录名称。对于JDBC-ODBC数据
库和许多其它的数据库,它可被设置为null。这些数
据库的目录条目实际上为它们在文件系统中的绝对
路径。 
schema
 要包括的数据库schema。许多数据库并不支持
schema,而对于其它的数据库,它为数据库所有者
的用户名称。 
tablemask
 描述你要获取的表的名称的一个掩码。若你想获取
所有的表名,将它设为通配符%。注意SQL用%作
为通配符,而不是PC上的*。 
types[]
 描述你奥获取的表的种类的一个字符串数组。数据
库中通常包括一些用于内部管理的表,而这些表对
用户来说是毫无用处的。若被设为null,你将得到所
有的表。若使该数组只包括一个元素,且将该元素
设为字符串“TABLES”,你将得到用户所感兴趣
的那些表。 

获得数据库中表的名称相对于先得到DatabaseMetaData对象,然后再从中取得表的名称。 

con = DriverManager.getConnection(url);
//get the database metadata
dma =con.getMetaData();
//now dump out the names of the tables in the database
String[] types = new String[1];
types[0] = "TABLES"; //set table type mask
//note the %-sign is a wild card (not '*')
results = dma.getTables(null, null, "yourtablename", types);

如我们在前面所做的,打印出表的名称: 

boolean more = results.next();
if (more) 
{
//yourtablename已经存在!
}

将所有代码包括在try程序块中。 


但我建议还是用yanchang(笨笨) ,比较方便

|
试试ResultSet rs = connect.getMetaData().getTables(null, null, "表名", null);看看rs中有没有你想要的表,详见DatabaseMetaData类的getTables方法。

|
有个很笨的方法
try
{
Statement stmt = connect.createStatement();
stmt.executeQuery("select count(*) from yourTable");

}
catch(SQLException e)
{
   System.out.print("不存在!"+ e.getMessage());
}

    
 
 

您可能感兴趣的文章:

  • 请问如何判断一个文件夹是否存在
  • 请问如何判断一个对象是否已经初始化???
  • 请问如何判断一个字符串是否为空呀?
  • 请问用什么方法能判断一个文件是否存在,谢谢!
  • 请问linux中如何判断内核是否已经启动。(在内核中写程序)
  • 请问,如何用程序判断一个用ftp传输的文件已经完成?
  • 请问如何判断从raw socket发出的包是哪个进程发送的?
  • 请问如何判断 request.getparameter 是否有值
  • 请问怎么判断裸设备是否可以删除
  • 请问如何判断左右同时按键??
  • 请问如何判断目录是否存在?
  • 请问jsp有没方法判断窗口有没有框架???
  • 请问有没有办法判断一串字符串是否经过base64编码
  • 请问:怎么判断linux服务器的网站系统是不是中毒了?
  • 请问一下怎么判断输入的IP,是正确的,如:IP地址中没有字母,数字不超过255。
  • 请问怎么判断一个路径是否存在(C语言)
  • 请问如何判断一个文件是不是可执行文件?
  • 请问如何判断一个站点是否支持断点续传!
  • 请问如何在qt程序中判断当前的操作系统和环境??
  • 请问如何判断一串字符是数字
  • 请问soralis下怎么写脚本判断进程是否存在,不存在则启动?
  • 新手请问,检查某个指定文件是否存在于opt目录下,如果存在则把该文件名保存到文本文件里,用Shell脚本如何写?请简写代码供参,谢谢。PM5
  • 请问怎么重新编译后里面的文件还存在呢?
  • 请问我怎么样才能知道一个特定的数据库中是否存在某一个表
  • 请问用javac编译一般*.java能通过,但不能编译Servlet写的*.java.提示javax.servlet.http不存在。
  • 请问哪个方法可以检查Map中有某个键存在?
  • 请问怎么用JAVA向一个已经存在的文本文件输入字符,也就写文件?谢谢!(急!)
  • 请问在solaris X86 的安装中,应该如何分区呢?其大小应该如何定呢?可否存在windows和solaris两种系统在一块硬盘上?
  • 请问我应该如何去找寻问题的存在
  • 请问为什么我的servlet程序,在编译时总是会出现包javax.servlert和包javax.servlet.http不存在的错误,我在环境变量classpath种已经登记了servlet.jar的位置了。如何解决?
  • 编译beans时,出现"包 javax.servlet 不存在"错误提示,请问怎样解决???
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请问unix/linux下动态连接库和静态连接库有什么区别?
  • 请问连接本机数据库的JDBC,和连接远程的JDBC有没有区别?
  • 我在telnet到linux上的时候报不能打开到主机的连接, 在端口23: 连接失败 请问是什么原因
  • 请问我有一个连接cn 如果我在对它操作以后不关闭它会有什么影响吗?想法是一个页面有二个提交,想公用一个连接。
  • 请问谁知道连接池中的参数设置?
  • 请问连接池的工作原理和实现
  • 网络技术 iis7站长之家
  • 请问在linux上tcp能够接收的最大连接数是多少?
  • 请问一个socket在listen()之后如果把它close()了,那之前已经用子进程处理的连接还在不在?
  • 请问在UNIX下如何限制同一IP的telnet连接数
  • 请问如何主动拒绝连接
  • 急!请问怎样用jrelibrt.jar进行JDBC-ODBC连接?在线等!!
  • 请问JDBC和JDBC-ODBC有什么区别?是不是连接的时候也有所不同。
  • 请问诸位高手:如何在服务器上得到正在连接的客户端IP??
  • 请问javaBean能不能进行非本机的socket连接
  • 请问用resin作服务器,如何与mysql数据库连接?
  • 请问jbuilder 6.0.怎么好多帮助说连接不上
  • 请问JAVA怎么连接Sybase ASA 6.0 ?
  • 请问用ORALCE建一个库,在网页上的连接直接访问这个库,怎么构建?100分
  • 请问windows下用那个LINUX连接工具最好
  • 请问:我知道路由器的telnet密码,但忘记了enable 密码,请问如何是好?
  • 请问那里有SYBASE的jbdb 2.0下载;jspsmartupload可以直接将文件上传到数据库,请问如何使用
  • 请问最新的reahat9.0是基于什么核心的?2.4?2.6?请问那里能下载?
  • 请问:请问哪里有关于linux基本操作命令讲解的资料下载,最好是幻灯片格式的.
  • 请问,我试图用#admintool&图形工具命令来安装sun workshop5.0,为什么进入的却是用户管理界面?请问具体该如何在solaris下安装应用软件
  • 请问在Redhat 9里,我从登录就是图形介面,请问如何在图形介面内进入命令行方式呢,谢谢
  • 请问玩过SOLARIS的高手门,在不正常关机后,就不能启动到windows公用桌面了,只能在命令提示模式下了,请问怎么解决这个问题啊?急~!~!
  • 请问:我在redhat下装了bochs-2.2.1-1.rpm,.装了后,想设置一下,但找不到bochsrc.fda.bxrc,请问这个文件在哪个曰录下啊。
  • 请问:在配置Qt时,很多文档都说在.profile,.login里加东西,但是我好像没有发现有这两个文件上,请问这些文件在哪个目录下啊
  • 请问:在GCC里的C程序里的变量的声明是不是只能在前面,而且相同类型的变量的声明只能放在一起?如果不是,请问怎么样可以解决这个问题.
  • 请问各位大虾,小弟今天开始学jsp了,这学期我们有java课,所以已经下载了jdk(好象是1.2),请问我的98环境怎么配置jsp环境呀?我的jdk可以运行.java程序,别的我就不知道了....谢谢!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3