Oracle——7.练习

用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"));
		}
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值