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注入攻击,更安全
相关推荐
Themberfue1 分钟前
SQL ①-数据库 || MySQL
数据库·sql·mysql·数据库系统·数据库管理系统
非 白2 分钟前
【Java】代理模式
java·开发语言·代理模式
Good Note12 分钟前
Golang的静态强类型、编译型、并发型
java·数据库·redis·后端·mysql·面试·golang
RisingWave中文开源社区44 分钟前
一文详解物化视图(MV):定义、优势和用例
数据库·sql·数据分析
我就是我3521 小时前
记录一次SpringMVC的406错误
java·后端·springmvc
向哆哆1 小时前
Java应用程序的跨平台性能优化研究
java·开发语言·性能优化
PingCAP1 小时前
TiDB Chat2Query 深度解析:我们如何打造一款更高效、准确的智能 SQL 生成工具?
数据库
ekkcole2 小时前
windows使用命令解压jar包,替换里面的文件。并重新打包成jar包,解决Failed to get nested archive for entry
java·windows·jar
想做富婆2 小时前
数仓搭建实操(传统数仓oracle):[构建数仓层次|ODS贴源层]
数据库·oracle·数仓
威哥爱编程2 小时前
如何解决 MySQL 数据库服务器 CPU 飙升的情况
数据库·mysql