Android 判断数据库中是否存在某个表

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. </pre><p style="margin-top:0px; margin-bottom:0px; padding-top:0px; padding-bottom:0px; font-family:Arial; font-size:14px; line-height:26px"><pre name="code" class="java">public boolean tableIsExist(String tabName, SQLiteDatabase db) {  
  2.         boolean result = false;  
  3.         if (tabName == null) {  
  4.             return false;  
  5.         }  
  6.         Cursor cursor = null;  
  7.         try {  
  8.   
  9.             String sql = "select count(*) as c from sqlite_master where type ='table' and name ='" + tabName.trim() + "' ";  
  10.             cursor = db.rawQuery(sql, null);  
  11.             if (cursor.moveToNext()) {  
  12.                 int count = cursor.getInt(0);  
  13.                 if (count > 0) {  
  14.                     result = true;  
  15.                 }  
  16.             }  
  17.   
  18.         } catch (Exception e) {  
  19.             // TODO: handle exception  
  20.         }  
  21.         return result;  
  22.     }  


对sqlite_master表查询不但可以得到建表的sql语句,还可以获取该数据库内的trigger信息

 

而在纯java环境下对SQL数据库查询是否目标表格存在的时候可以更简单:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. java.sql.Connection con = getYourConnection();   
  2.      
  3. ResultSet rs = con.getMetaData().getTables(nullnull"yourTable"null );  
  4. if (rs.next()) {  
  5. //yourTable exist  
  6. }else {  
  7. //yourTable not exist  
  8. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值