@Test
public void testUpdate(){
// update("insert into account values(null , ?,?)" , "aa",10);
// update("delete from account where id = ?" ,14);
// update("update account set money = ? where id = ?" , 9 ,8,19,10,10,10);
update02("update account set money = ? where id = ?" , 800 ,6,19,10,10,10);
}
//select * from bb;
//通用的增删改功能
/**
* 以参数个数为准
* @param sql 需要操作的sql语句
* @param args 可变参数, 有几个占位符,就写几个参数进来。
*/
public void update(String sql ,Object ... args) {
Connection conn = null;
PreparedStatement ps=null;
try {
conn = JDBCUtil02.getConn();
ps = conn.prepareStatement(sql);
for (int i = 0; i < args.length; i++) {
//因为不知道是什么类型的数据,所以都使用setObject来对待。
ps.setObject(i+1, args[i]);
}
ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}finally {
JDBCUtil.release(conn, ps);
}
}
/**
* 打算以问号个数为准
* @param sql 需要操作的sql语句
* @param args 可变参数, 有几个占位符,就写几个参数进来。
*/
public void update02(String sql ,Object ... args) {
Connection conn = null;
PreparedStatement ps=null;
try {
conn = JDBCUtil02.getConn();
ps = conn.prepareStatement(sql);
//元数据
//获取到有几个问号,占位符
ParameterMetaData metaData = ps.getParameterMetaData();
int count = metaData.getParameterCount();
for (int i = 0; i < count; i++) {
//因为不知道是什么类型的数据,所以都使用setObject来对待。
ps.setObject(i+1, args[i]);
}
ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}finally {
JDBCUtil.release(conn, ps);
}
}