java语言如何判断oracle是否存在某张表?急,求大神指点啊!!

Stringtname=“user”;Stringsql="ifexists(select1fromuser_tableswheretable_name='"+tname... String tname=“user”; String sql="if exists(select 1 from user_tables where table_name='"+tname+"')";
Connection conn=null;Statement st =null;ResultSet rs =null;
try {conn =DBUtil.getConn(); st=conn.createStatement();rs=st.executeQuery(sql);
//如果表存在则直接往数据里插入数据
if(rs.next()){String sql1="insert into "+tname+" values(?,?,?,?,?,?)";} 这样错在哪,总是报无效的sql语句。
展开
 我来答
story5324
推荐于2018-04-12 · 超过12用户采纳过TA的回答
知道答主
回答量:31
采纳率:0%
帮助的人:33.2万
展开全部
public boolean validateTableExist(String tableName){
int result = 0;
String sql = "SELECT COUNT(*) FROM USER_OBJECTS WHERE OBJECT_NAME = UPPER('"+tableName+"')";
Connection conn = this.getSession().connection();
Statement st = null;
ResultSet rs = null;
try{
st = conn.createStatement();
rs = st.executeQuery(sql);
rs.next();
result = rs.getInt(1);
}catch(Exception e){
e.printStackTrace();
}finally{
this.util.closeAll(rs, st, conn);
}
return result==0?false:true;
}

JDBC的完整方法,CloseAll方法就不给你写了.如果表存在就返回True,不存在返回False,可以直接用在你的IF判断中:
if(validateTableExist(tname)){
String sql1="insert into "+tname+" values(?,?,?,?,?,?)";
....................
}
jackylvxg
2013-05-30 · TA获得超过243个赞
知道小有建树答主
回答量:386
采纳率:0%
帮助的人:215万
展开全部
可以用Oracle的辅助表 Select * from User_tables where table_name='xxxx' 如果返回结果为空, 说明表不存在
追问
我是用jdbc写的,该如何执行这句话呢?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
pangzhiming
2013-05-30 · TA获得超过374个赞
知道小有建树答主
回答量:787
采纳率:100%
帮助的人:339万
展开全部
select 1 from user_tables where table_name='表名'
如果=1 表存在
追问
我是用jdbc写的,该如何执行这句话呢?
追答
String tname=“user”;
String sql="select 1 from user_tables where table_name='"+tname;
Connection conn=null;Statement st =null;ResultSet rs =null;
try {conn =DBUtil.getConn(); st=conn.createStatement();rs=st.executeQuery(sql);
//如果表存在则直接往数据里插入数据
if(rs.next()){String sql1="insert into "+tname+" values(?,?,?,?,?,?)";}
和obj比较。主要代码就这样
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式