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注入攻击,更安全
相关推荐
小阿宁的猫猫4 分钟前
sqlmap的使用
sql·网络安全·php
SirLancelot111 分钟前
AI大模型-基本介绍(一)RAG、向量、向量数据库
数据库·人工智能·ai·向量·向量数据库·rag
spencer_tseng11 分钟前
springcloud + javaframework + h5
java·spring·spring cloud
李慕婉学姐17 分钟前
Springboot面向电商的仓库管理系统05uc4267(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
imbackneverdie21 分钟前
AI工具如何重塑综述写作新体验
数据库·人工智能·考研·自然语言处理·aigc·论文·ai写作
月明长歌37 分钟前
【码道初阶】【Leetcode606】二叉树转字符串:前序遍历 + 括号精简规则,一次递归搞定
java·数据结构·算法·leetcode·二叉树
原来是好奇心38 分钟前
深入Spring Boot源码(八):高级特性与扩展点深度解析
java·源码·springboot
oioihoii42 分钟前
C++共享内存小白入门指南
java·c++·算法
@淡 定1 小时前
线程安全的日期格式化:避免 SimpleDateFormat 并发问题
java