jdbc建立java和sql的连接

jdbc建立java和sql的连接

一.导包

1.首先新建一个项目

2.再新建一个包lib

3.把下好的sql包粘贴到lib里

4.右键lib包点击add as library

结束

二.注册驱动:
java 复制代码
DriverManager.registerDriver(new Driver());
三.建立与数据库的连接:
java 复制代码
 String url="jdbc:mysql://127.0.0.1:sql端口号/schooldb?serverTimezone=Asia/Shanghai";
        String user="root"; //账户
        String password="root"; //密码
        Connection connection=DriverManager.getConnection(url,user,password);
四.发送sql
java 复制代码
 Statement statement=connection.createStatement();
 statement.executeUpdate("insert into major(name)value('数学')");
五.关闭与数据库的连接:
java 复制代码
statement.close();
connection.close();

插入方法eg:

java 复制代码
public static void main(String[] args) throws SQLException {
        SqlOperate.insert("lzy","男","1979-4-21","13152113467",1.88);
    }
    public static void insert(String name,String gender, String birthday,String phone,double height) throws SQLException {
        //注册驱动
        DriverManager.registerDriver(new Driver());
        String url="jdbc:mysql://127.0.0.1:3306/schooldb?serverTimezone=Asia/Shanghai";
        String user="root";
        String password="root";
        //建立与数据库的连接
        Connection connection=DriverManager.getConnection(url,user,password);
        //发送sql
        Statement statement=connection.createStatement();
        statement.executeUpdate("update student set name='"+name+"',gender='"+gender+"',birthday='"+birthday+"',phone='"+phone+"',height="+height+"");
        //关闭与数据库的连接
        statement.close();
        connection.close();
    }
PreparedStatement实现发送sql
java 复制代码
PreparedStatement ps=connection.prepareStatement("insert into major(name)value(?)");    //?是占位符,表示要插入一个参数
        ps.setObject(1,"智能");   //1表示在第一个?位置插入数据
        ps.executeUpdate();
java 复制代码
PreparedStatement ps=connection.prepareStatement("update student set name=?,gender=?,birthday=?,phone=?,height=? where number=?");
        ps.setObject(1,name);
        ps.setObject(2,gender);
        ps.setObject(3,birthday);
        ps.setObject(4,phone);
        ps.setObject(5,height);
        ps.setObject(6,number);
        ps.executeUpdate();
PreparedStatement和Statement本质区别:PS的?占位符可以在参数进来时进行验证,防止sql注入攻击,更安全
相关推荐
cfm_291415 分钟前
Redis Stack 零基础入门
数据库·redis·缓存
我不是懒洋洋15 分钟前
手写一个异步日志库:从printf到高性能无锁日志
java·c语言·开发语言·c++·visual studio
李少兄19 分钟前
Java 工程化基石:标准目录结构与 META-INF 元信息机制
java·开发语言
海南java第二人21 分钟前
ClickHouse 列式存储深度解析:优点、缺点与选型实战
数据库·clickhouse
就叫_这个吧25 分钟前
理解Java反射机制和内省机制应用与实践
java·开发语言·反射
李白客32 分钟前
MySQL迁移操作手册:一次完整迁移的实战路径
数据库·mysql
未若君雅裁1 小时前
synchronized 底层原理:Monitor、对象头、Mark Word 与锁升级
java
m0_752035631 小时前
markdown语言格式
java
布朗克1681 小时前
12 封装与构造方法
java·开发语言·封装·构造方法
晴天¥1 小时前
Oracle 19c RAC修改监听默认端口
数据库·oracle