[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();
    }
}
相关推荐
一定要AK2 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao2 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
KevinCyao2 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
科技小花2 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸2 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain2 小时前
linux个人心得22 (mysql)
数据库·mysql
迷藏4942 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
阿里小阿希3 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神3 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员3 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全