springjdbc+mysql判断数据库以及数据库表是否存在

最近使用Springjdbc+Mysql来开发一个项目,记录两个问题。

  1. 判断数据库是否存在

   方法1:使用原生Mysql语句,use database方式,并执行,根据执行结果是否出现异常来判断数据库是否存在,代码如下

public boolean isDbExist(String dbName) {
		try {
			String sql = "USE "+dbName;
			jdbcTemplate.execute(sql);
			return true;		
		} catch (Exception e) {
			System.out.println("数据库不存在");	
			return false;
		}			
	}

    方法2:使用建立数据库连接的方法来判断,也是根据是否出现异常,但是此方法如果是多数据源的话需要反复切换数据源,不是很方便

public boolean isDbExist(String dbName) {
		Connection conn = null;
		try {
			conn = jdbcTemplate.getDataSource().getConnection();
			return true;		
		} catch (Exception e) {
			System.out.println("数据库不存在");			
		}finally{
			try {
				conn.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}			
		}		
		return false;
	}


   2.判断数据库的某个表是否存在

方法比较常规,就是根据表名查询一下,看看是否有记录,有记录即表存在,否则不存在

public boolean isTableExist(String tableName) {
		Connection conn = null;
		ResultSet rs = null;
		try {
			conn = jdbcTemplate.getDataSource().getConnection();
			rs = null;
			DatabaseMetaData data = conn.getMetaData();
			String[] types = {"TABLE"};
			rs = data.getTables(null, null, tableName, types);
			if(rs.next()){
				return true;
			}			
		} catch (Exception e) {
			e.printStackTrace();
		}finally{
			try {
				rs.close();
				conn.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}			
		}
		
		return false;
	}



转载于:https://my.oschina.net/u/2362627/blog/605840

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值