一、判斷數據庫表是否存在:
首先要拿到數據庫連接conn,調用DatabaseMetaData dbmd = conn.getDataMeta();之後調用如下方法:
復制代碼 代碼如下:
/**
* 根據表名,判斷數據庫表是否存在
* @param tableName
* @return true:存在該表,false:不存在該表
*/
public boolean hasTable(String tableName) {
Init();
boolean result = false; //判斷某一個表是否存在
try{
ResultSet set = dbmd.getTables (null, null, tableName, null); //獲取查找結果
while (set.next()) { //如果查找結果不為空,則說明存在該表
result = true; //將返回結果置為true
}
}catch(Exception e){
e.printStackTrace();
}
return result;
}
二、修改表名:
首先依然要拿到數據庫連接conn和數據庫描述對象dbmd以及Statement對象st,之後調用如下方法
復制代碼 代碼如下:
/**
* 修改表名
* @param srcTableName 源表名
* @param newTableName 新表名
* @return true:修改表名成功,false:修改表名失敗
*/
public boolean renameTable(String srcTableName,String newTableName){
Init();
boolean result = false;
StringBuffer sql = new StringBuffer();
try{
String dataBaseType = dbmd.getDatabaseProductName(); //獲取數據庫類型
if(("Microsoft SQL Server").equals(dataBaseType)){ //sqlServer
try{
sql.append("EXEC sp_rename"+" "+srcTableName).append(",").append(newTableName);
int temp = 0;
temp = st.executeUpdate(sql.toString()); //執行更新操作,返回結果
if(1==temp){
result = true; //將返回值設為true
}
}catch(Exception e){
e.printStackTrace();
}
}else if(("HSQL Database Engine").equals(dataBaseType)||("MySQL").equals(dataBaseType)){ //hsql和mysql
try{
sql.append("ALTER TABLE"+" "+srcTableName+" "+"RENAME TO"+" "+newTableName);
int temp = 1;
temp = st.executeUpdate(sql.toString()); //執行更新操作,返回結果
if(0==temp){
result = true; //將返回值設為true
}
}catch(Exception e){
e.printStackTrace();
}
}else{ //尚未實現對oracle和db2判斷
}
}catch(Exception e){
e.printStackTrace();
}
//System.out.println(result);
return result;
}