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

[java]  view plain  copy
 
  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
 
  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. }  

你可能感兴趣的:(Android 判断数据库中是否存在某个表)