网站首页 > 精选教程 正文
学习过java肯定对MySQL都相当的熟悉,大家日常工作中可能用Mybatis、JPA等持久层框架比较多。其实这些持久层框架的底层都是用原生的jdbc来操作MySQL数据库的。下面就给大家介绍一下原生jdbc;
前提:需要安装好MySQL数据库,并且有可操作的数据库表;我的数据库表是一张user表,里面有2个字段:id,name;
1.首先肯定是添加依赖,由于是原生的jdbc,需要原生jdbc驱动的依赖,不可以添加其他框架整合的jdbc。(如springboot的jdbc)
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.28</version>
</dependency>
2.编写java代码,连接数据库进行操作。(由于比较原生,所以只需要一个main方法即可,不需要有web工程)
// 1. 建立连接
// 加载数据库驱动
Class.forName("com.mysql.jdbc.Driver");
// 数据库连接地址 jdbc:mysql://数据库地址:数据库端口/数据库名称
String url = "jdbc:mysql://localhost:3306/test";
// 账号
String username = "root";
// 密码
String password = "123456";
// 利用上述信息获取连接
Connection con = DriverManager.getConnection(url,username,password);
// 2. 对数据库进行操作
// a)增删改
// 插入sql语句
String sql1 = "INSERT INTO user (id, name) VALUES('2022','冰墩墩')";
// 使用连接获取Statement
Statement stat1 = con.createStatement();
// 执行sql,返回结果产生变化的总行数
int row = stat1.executeUpdate(sql1);
System.out.println("返回结果产生变化的总行数row = " + row);
// b)查询
// 查询sql语句
String sql2 = "SELECT * FROM user";
// 使用连接获取Statement
Statement stat2 = con.createStatement();
// 执行sql,返回结果集
ResultSet rs = stat2.executeQuery(sql2);
// 遍历结果集 getString获取的该字段是数据库对应的varchar类型
while(rs.next()){
System.out.println(rs.getString("id")+" "+rs.getString("name"));
}
//4.关闭所有连接
rs.close();
stat1.close();
stat2.close();
con.close();
}
控制台打印结果:
返回结果产生变化的总行数row = 1
2022 冰墩墩
注意:上述代码使用了Statement来操作数据库,这种操作会产生SQL注入的风险,因此可以使用下面PreparedStatement的代码来避免该风险:
//防注入解决方案:将Statement换成PreparedStatement
//a)增删改
String sql3 = "UPDATE user SET id=?,name=? WHERE id=?";
// 上面的sql语句有几个问号占位,下面设置占位参数的值,这样可以避免sql注入
PreparedStatement pst = con.prepareStatement(sql3);
// 设置第一个,第二个,第三个参数值
pst.setObject(1, "2023");
pst.setObject(2, "雪容融");
pst.setObject(3, "2022");
// 执行
int row3 = pst.executeUpdate();
System.out.println("返回结果产生变化的总行数row = " + row3);
//b)查询
String id = "2023";
String sql4 = "SELECT * FROM user WHERE id=? ";
PreparedStatement pst4 = con.prepareStatement(sql4);
pst4.setObject(1, id);
ResultSet rs4 = pst4.executeQuery();
while(rs4.next()){
System.out.println(rs4.getString("id")+" "+rs4.getString("name"));
}
//pst.close();
输出结果:
返回结果产生变化的总行数row = 1
2023 雪容融
ok,原生jdbc给大家基本介绍完毕,大家有什么疑惑可以评论区讨论,作者看到都会回复哒[送心]
猜你喜欢
- 2024-10-29 Java中最简单的连接Oracle数据库和Mysql数据库的方式
- 2024-10-29 Java | MySQL 分布函数、前后函数你认识吗?
- 2024-10-29 Javaweb知识 day02 mysql数据库 javaweb程序设计任务教程黑马程序员电子版
- 2024-10-29 Jenkins Pipeline 连接 MySQL 数据库
- 2024-10-29 银四将近,Java程序员临时抱佛脚也要啃下的硬骨头——MySQL
- 2024-10-29 Java代码中,如何监控Mysql的binlog?
- 2024-10-29 Java环境+Mysql+Tomcat部署JavaWeb项目到云服务器(十分详细)
- 2024-10-29 mysql-connector-java与MySQL 8.X版本建立连接
- 2024-10-29 java连接mysql数据库达成数据查询详细教程
- 2024-10-29 Java代码操作MySQL java操作mysql语法
你 发表评论:
欢迎- 04-11Java面试“字符串三兄弟”String、StringBuilder、StringBuffer
- 04-11Java中你知道几种从字符串中找指定的字符的数量
- 04-11探秘Java面试中问的最多的String、StringBuffer、StringBuilder
- 04-11Python字符串详解与示例(python字符串的常见操作)
- 04-11java正则-取出指定字符串之间的内容
- 04-11String s1 = new String("abc");这句话创建了几个字符串对象?
- 04-11java判断字符串中是否包含某个字符
- 04-11关于java开发中正确的发牌逻辑编写规范
- 最近发表
-
- Java面试“字符串三兄弟”String、StringBuilder、StringBuffer
- Java中你知道几种从字符串中找指定的字符的数量
- 探秘Java面试中问的最多的String、StringBuffer、StringBuilder
- Python字符串详解与示例(python字符串的常见操作)
- java正则-取出指定字符串之间的内容
- String s1 = new String("abc");这句话创建了几个字符串对象?
- java判断字符串中是否包含某个字符
- 关于java开发中正确的发牌逻辑编写规范
- windows、linux如何后台运行jar(并且显示进程名)
- 腾讯大佬私人收藏,GitHub上最受欢迎的100个JAVA库,值得学习
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)