DROP TABLE IF EXISTS `school`.`student`;
CREATE TABLE `school`.`student` (
`id` int(11) NOT NULL default '0',
`name` varchar(20) default NULL,
`sex` varchar(10) default NULL,
`age` int(10) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `student` VALUES ('201201', '张三', '男', '21');
INSERT INTO `student` VALUES ('201202', '李四', '男', '22');
INSERT INTO `student` VALUES ('201203', '王五', '女', '20');
INSERT INTO `student` VALUES ('201204', '赵六', '男', '21');
INSERT INTO `student` VALUES ('201205', '小红', '女', '19');
INSERT INTO `student` VALUES ('201206', '小明', '男', '22');
【示例代码 】
package com.hebut.util;
public class DBHelperApp {
/**
* 增加【 Add 】
*/
public static void main(String[] args) {
// 第一种情况
String sql1="Insert Into student Values ('201208', ' 张三 ', ' 男 ', '21')";
System.out .println(DBHelper.executeNonQuery (sql1));
// 第二种情况
String sql2="Insert Into student Values (?,?,?,?)";
Object[] obj = new Object[]{"201209"," 张三 ", " 男 ", "21"};
System.out .println(DBHelper.executeNonQuery (sql2,obj));
}
}
【运行结果 】
1)控制台
1
1
2)数据库
【示例代码 】
package com.hebut.util;
public class DBHelperApp {
/**
* 删除【 Del 】
*/
public static void main(String[] args) {
// 第一种情况
String sql1="Delete From student Where id='201202'";
System.out .println(DBHelper.executeNonQuery (sql1));
// 第二种情况
String sql2="Delete From student Where id=? And name=?";
Object[] obj = new Object[]{"201208"," 张三 "};
System.out .println(DBHelper.executeNonQuery (sql2,obj));
}
}
【运行结果 】
1)控制台
1
1
2)数据库
从图中可以看出id为"201202 "和"201208 "已经删除。
【示例代码 】
package com.hebut.util;
public class DBHelperApp {
/**
* 修改【 Update 】
*/
public static void main(String[] args) {
// 第一种情况
String sql1="Update student Set age='27' Where id='201207'";
System.out .println(DBHelper.executeNonQuery (sql1));
// 第二种情况
String sql2="Update student Set name=? Where id=?";
Object[] obj = new Object[]{" 张二 ","201201"};
System.out .println(DBHelper.executeNonQuery (sql2,obj));
}
}
【运行结果 】
1)控制台
1
1
2)数据库
备注 :后面的操作都以上面数据为基准。
【示例代码 】
package com.hebut.util;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DBHelperApp {
/**
* 查询【 Query 】
* @throws SQLException
*/
public static void main(String[] args) throws SQLException {
// 第一种情况
String sql1="Select * From student";
// 第一步:查询
ResultSet rs1 = DBHelper.executeQuery (sql1);
// 第二步:输出
while (rs1.next()){
System.out .println(" 姓名: "+rs1.getString(2));
}
// 第三步:关闭
DBHelper.free (rs1);
// 第二种情况
String sql2="Select * From student Where name=?";
Object[] obj = new Object[]{" 张三 "};
// 第一步:查询
ResultSet rs2 = DBHelper.executeQuery (sql2,obj);
// 第二步:输出
while (rs2.next()){
System.out .println(" 学号: "+rs2.getString(1));
}
// 第三步:关闭
DBHelper.free (rs2);
}
}
【运行结果 】
姓名:张二
姓名:王五
姓名:赵六
姓名:小红
姓名:小明
姓名:张三
姓名:张三
学号: 201207
学号: 201209
【示例代码 】
package com.hebut.util;
public class DBHelperApp {
/**
* 获取查询行数
*/
public static void main(String[] args) {
// 第一种情况
String sql1="Select * From student";
System.out .println(DBHelper.getCount (sql1));
// 第二种情况
String sql2="Select * From student Where name=?";
Object[] obj = new Object[]{" 张三 "};
System.out .println(DBHelper.getCount (sql2,obj));
}
}
【运行结果 】
7
2
【示例代码 】
package com.hebut.util;
public class DBHelperApp {
/**
* 判断记录存在
*/
public static void main(String[] args) {
// 第一种情况
String sql1="Select * From student";
System.out .println(DBHelper.isExist (sql1));
// 第二种情况
String sql2="Select * From student Where name=?";
Object[] obj = new Object[]{" 张五 "};
System.out .println(DBHelper.isExist (sql2,obj));
}
}
【运行结果 】
true
false
package com.hebut.util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet ;
import java.sql.SQLException;
import java.sql.Statement;
public final class DBHelper {
// 此方法为获取数据库连接
public static Connection getConnection() {
Connection conn = null ;
try {
String driver = "com.mysql.jdbc.Driver"; // 数据库驱动
String url = "jdbc:MySQL://127.0.0.1:3306/school";// 数据库
String user = "root"; // 用户名
String password = "hadoop"; // 密码
Class.forName (driver); // 加载数据库驱动
if (null == conn) {
conn = DriverManager.getConnection (url, user, password);
}
} catch (ClassNotFoundException e) {
System.out .println("Sorry,can't find the Driver!");
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
/**
* 增删改【 Add 、 Del 、 Update 】
*
* @param sql
* @return int
*/
public static int executeNonQuery(String sql) {
int result = 0;
Connection conn = null ;
Statement stmt = null ;
try {
conn = getConnection ();
stmt = conn.createStatement();
result = stmt.executeUpdate(sql);
} catch (SQLException err) {
err.printStackTrace();
free (null , stmt, conn);
} finally {
free (null , stmt, conn);
}
return result;
}
/**
* 增删改【 Add 、 Delete 、 Update 】
*
* @param sql
* @param obj
* @return int
*/
public static int executeNonQuery(String sql, Object... obj) {
int result = 0;
Connection conn = null ;
PreparedStatement pstmt = null ;
try {
conn = getConnection ();
pstmt = conn.prepareStatement(sql);
for (int i = 0; i < obj.length; i++) {
pstmt.setObject(i + 1, obj[i]);
}
result = pstmt.executeUpdate();
} catch (SQLException err) {
err.printStackTrace();
free (null , pstmt, conn);
} finally {
free (null , pstmt, conn);
}
return result;
}
/**
* 查【 Query 】
*
* @param sql
* @return ResultSet
*/
public static ResultSet executeQuery(String sql) {
Connection conn = null ;
Statement stmt = null ;
ResultSet rs = null ;
try {
conn = getConnection ();
stmt = conn.createStatement();
rs = stmt.executeQuery(sql);
} catch (SQLException err) {
err.printStackTrace();
free (rs, stmt, conn);
}
return rs;
}
/**
* 查【 Query 】
*
* @param sql
* @param obj
* @return ResultSet
*/
public static ResultSet executeQuery(String sql, Object... obj) {
Connection conn = null ;
PreparedStatement pstmt = null ;
ResultSet rs = null ;
try {
conn = getConnection ();
pstmt = conn.prepareStatement(sql);
for (int i = 0; i < obj.length; i++) {
pstmt.setObject(i + 1, obj[i]);
}
rs = pstmt.executeQuery();
} catch (SQLException err) {
err.printStackTrace();
free (rs, pstmt, conn);
}
return rs;
}
/**
* 判断记录是否存在
*
* @param sql
* @return Boolean
*/
public static Boolean isExist(String sql) {
ResultSet rs = null ;
try {
rs = executeQuery (sql);
rs.last();
int count = rs.getRow();
if (count > 0) {
return true ;
} else {
return false ;
}
} catch (SQLException err) {
err.printStackTrace();
free (rs);
return false ;
} finally {
free (rs);
}
}
/**
* 判断记录是否存在
*
* @param sql
* @return Boolean
*/
public static Boolean isExist(String sql, Object... obj) {
ResultSet rs = null ;
try {
rs = executeQuery (sql, obj);
rs.last();
int count = rs.getRow();
if (count > 0) {
return true ;
} else {
return false ;
}
} catch (SQLException err) {
err.printStackTrace();
free (rs);
return false ;
} finally {
free (rs);
}
}
/**
* 获取查询记录的总行数
*
* @param sql
* @return int
*/
public static int getCount(String sql) {
int result = 0;
ResultSet rs = null ;
try {
rs = executeQuery (sql);
rs.last();
result = rs.getRow();
} catch (SQLException err) {
free (rs);
err.printStackTrace();
} finally {
free (rs);
}
return result;
}
/**
* 获取查询记录的总行数
*
* @param sql
* @param obj
* @return int
*/
public static int getCount(String sql, Object... obj) {
int result = 0;
ResultSet rs = null ;
try {
rs = executeQuery (sql, obj);
rs.last();
result = rs.getRow();
} catch (SQLException err) {
err.printStackTrace();
} finally {
free (rs);
}
return result;
}
/**
* 释放【 ResultSet 】资源
*
* @param rs
*/
public static void free(ResultSet rs) {
try {
if (rs != null ) {
rs.close();
}
} catch (SQLException err) {
err.printStackTrace();
}
}
/**
* 释放【 Statement 】资源
*
* @param st
*/
public static void free(Statement st) {
try {
if (st != null ) {
st.close();
}
} catch (SQLException err) {
err.printStackTrace();
}
}
/**
* 释放【 Connection 】资源
*
* @param conn
*/
public static void free(Connection conn) {
try {
if (conn != null ) {
conn.close();
}
} catch (SQLException err) {
err.printStackTrace();
}
}
/**
* 释放所有数据资源
*
* @param rs
* @param st
* @param conn
*/
public static void free(ResultSet rs, Statement st, Connection conn) {
free (rs);
free (st);
free (conn);
}
}