Java 使用execute方法执行Sql语句

本文转载自: http://www.cnblogs.com/linlf03/archive/2012/12/16/2820677.html 作者:linlf03 转载请注明该声明。

Java 使用execute方法执行Sql语句。

mysql.ini是一个配置文件。配置内容可以看上一篇。

class ExecuteSql {
	private String driver;
	private String url;
	private String user;
	private String pass;
	Connection conn;
	Statement stmt;
	ResultSet rs;
	public void initParam(String paramFile) throws Exception {
		Properties props = new Properties();
		props.load(new FileInputStream(paramFile));
		driver = props.getProperty("driver");
		url = props.getProperty("url");
		user = props.getProperty("user");
		pass = props.getProperty("pass");		
	}
	
	public void executeSql(String sql) throws Exception{
		try {
			Class.forName(driver);
			conn = DriverManager.getConnection(url,user,pass);
			stmt = conn.createStatement();
			boolean hasResultSet = stmt.execute(sql);
			if (hasResultSet) {
				rs = stmt.getResultSet();
				java.sql.ResultSetMetaData rsmd = rs.getMetaData();
				int columnCount = rsmd.getColumnCount();
				
				while (rs.next()) {
					for (int i = 0; i < columnCount; i++) {
						System.out.print(rs.getString(i+1) + "\t");
					}
					System.out.println();
					
				}
			}
			else {
				System.out.println("改SQL语句影响的记录有" + stmt.getUpdateCount() + "条");
			}
		} 
		finally
		{
			if (rs != null) {
				rs.close();
			}
			if (stmt != null) {
				stmt.close();
			}
			if (conn != null) {
				conn.close();
			}
		}
	}
	
	/**
	 * @param args
	 * @throws Exception 
	 */
	public static void main(String[] args) throws Exception {
		// TODO Auto-generated method stub
		
		ExecuteDDL ed = new ExecuteDDL();
		ed.initParam("src/mysql.ini");
	
		ed.executeSql("drop table if exists school"); //(insertSql);	
		ed.executeSql("create table school(id int, name varchar(50), addr varchar(50))");		
		ed.executeSql("insert into school values(1, 'No1', 'BeiJing')");	
		ed.executeSql("select * from school");	
	}
	

}

  执行结果为:

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值