用jdbc的方式实现员工表的增删改查
要求:查询实现模糊查询
要点:
- 内容 在替换占位符的时候,用的是'内容'
- 在替换占位符的时候,是有两个小单引号的
- SQL语句模糊查询可以用concat拼接
DataBase.java
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DataBase {
Connection conn;
// 连接
public void getConn() throws Exception{
Class.forName("oracle.jdbc.driver.OracleDriver");
conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","scott","123456");
}
// 增删改
public int DoExe(String sql,Object... obj) throws Exception {
getConn();
try {
PreparedStatement pstmt = conn.prepareStatement(sql);
for(int i=0;i<obj.length;i++){
pstmt.setObject(i+1, obj[i]);
}
return pstmt.executeUpdate();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return 0;
}
// 查询
public ResultSet Query(String sql,Object... obj) throws Exception {
getConn();
try {
PreparedStatement pstmt = conn.prepareStatement(sql);
for(int i=0;i<obj.length;i++) {
pstmt.setObject(i+1, obj[i]);
}
return pstmt.executeQuery();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
Test.java
import java.sql.ResultSet;
import java.util.Scanner;
// 用jdbc的方式实现员工表的增删改查
// 要求:查询实现模糊查询
public class Test {
public static void main(String[] args) throws Exception {
Scanner input = new Scanner(System.in);
DataBase db = new DataBase();
System.out.print("输入查询的姓名(可以模糊查询):");
String name = input.next();
// 内容 在替换占位符的时候,用的是'内容'
// 在替换占位符的时候,是有两个小单引号的
// 模糊查询的时候,SQL语句的写法
String sql = "select * from emp where ename like concat(concat('%',?),'%')";
ResultSet rs = db.Query(sql, name);
while(rs.next()) {
System.out.println(rs.getInt(1) + "----" + rs.getString(2) + "----" + rs.getInt("sal"));
}
}
}