[JDBC]PreparedStatement替代Statement

一.增

复制代码
    @Test
    public void testInsert() throws Exception {
        try(Connection con = ConnectDB();
            Scanner input = new Scanner(System.in)){

            System.out.print("请输入姓名:");
            String ename = input.next();//李四

            System.out.print("请输入薪资:");
            double salary = input.nextDouble();//15000

            System.out.print("请输入出生日期:");
            String birthday = input.next();//1990-1-1

            System.out.print("请输入性别:");
            char gender = input.next().charAt(0);//男
//        String gender = input.next();

            System.out.print("请输入手机号码:");
            String tel = input.next();//13578595685

            System.out.print("请输入邮箱:");
            String email = input.next();//zhangsan@atguigu.com

            //编写sql
            String sql = "insert into t_employee(ename,salary,birthday,gender,tel,email,hiredate) " +
                    "values(?,?,?,?,?,?,curdate())";

            //告诉数据库执行 INSERT 操作后,返回自动生成的主键值(比如自增 ID)
            PreparedStatement preparedStatement = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
            //需要填写?对应的值
            preparedStatement.setObject(1, ename);
            preparedStatement.setObject(2, salary);
            preparedStatement.setObject(3, birthday);
            preparedStatement.setObject(4, gender + "");//char变为String类型
            preparedStatement.setObject(5, tel);
            preparedStatement.setObject(6, email);

            int len = preparedStatement.executeUpdate();
            if(len > 0){
                System.out.println("添加成功! len = " +  len);
            }else{
                System.out.println("添加失败!");
            }
            preparedStatement.close();
        }
    }

一个关于PeparedStatement的insert的错误

二.删

复制代码
@Test
public void testDelete() throws Exception {
    String sql = "delete from t_employee where eid = ?";
    try(Connection con = ConnectDB();
        PreparedStatement ps = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);){
        ps.setInt(1,32);
        int len = ps.executeUpdate();
        if(len > 0){
            System.out.println("删除成功! len = " + len);
        }else{
            System.out.println("删除失败!");
        }
    }
    catch (Exception e){
        e.printStackTrace();
    }
}

三.改

复制代码
@Test
public void testUpdate() throws Exception {
    try(Connection con = ConnectDB();
    PreparedStatement ps = con.prepareStatement("update t_employee set ename = ? where eid = ?");
    Scanner input = new Scanner(System.in)){

        System.out.println("请输入要修改的姓名:");
        String ename = input.next();
        System.out.println("请输入要修改的员工ID:");
        int eid = input.nextInt();
        ps.setString(1,ename);
        ps.setInt(2, eid);

        int len = ps.executeUpdate();
        if(len > 0){
            System.out.println("修改成功! len = " + len);
        }else{
            System.out.println("修改失败!");
        }

    }catch(Exception e){
        e.printStackTrace();
    }
}
相关推荐
不知名的老吴24 分钟前
线程的生命周期之线程“插队“
java·开发语言·python
ANnianStriver34 分钟前
PetLumina-02-后端开发与前后端联调
java·ai·sa-token
zuYM4g7Dp1 小时前
NoSql数据库设计心得
数据库·nosql
杨了个杨89821 小时前
Keepalived + Nginx + HAProxy 高可用架构部署实战案例
java·nginx·架构
睡不醒男孩0308233 小时前
第七篇:揭秘 PostgreSQL 数据库内核级管控:CLup 深度架构设计与高可用底座技术白皮书
数据库·postgresql·clup
cmes_love3 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
马士兵教育3 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
swordbob4 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
snow@li4 小时前
Java:理解 Gradle / 后端项目的管家 / 打包SpringBoot 应用 / 完成编译、下载依赖、运行测试、打包 JAR/WAR / 速查表
java
牛油果子哥q4 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++