【2023.11.23】JDBC基本连接语法学习➹

1.导入jar包依赖:mysql-connector-java-8.0.27.jar

2.连接数据库!

3.无法解析类->导入java.sql.*,(将项目方言改为Mysql)

JDBC,启动!!

public class Main {public static void main(String[] args) {//1. 通过DriverManager来获得数据库连接try (Connection connection = DriverManager.getConnection("连接URL","用户名","密码");//2. 创建一个用于执行SQL的Statement对象Statement statement = connection.createStatement()){   //注意前两步都放在try()中,因为在最后需要释放资源!//3. 执行SQL语句,并得到结果集ResultSet set = statement.executeQuery("select * from 表名");//4. 查看结果while (set.next()){}}catch (SQLException e){e.printStackTrace();}
//5. 释放资源,try-with-resource语法会自动帮助我们close}
}

1. 通过DriverManager来获得数据库连接
当方法getConnection被调用时,DriverManager将尝试从初始化时加载的驱动程序中找到合适的驱动程序,并创建Connection。

(由于Connection和Statement都需要执行close方法,使用try-with-resources的语法可以简化代码书写)

2. 创建一个用于执行SQL的Statement对象
创建connetion(数据库连接对象),用于向数据库发送SQL语句的Statement对象。没有参数的SQL语句通常使用Statement对象执行。如果同一SQL语句被多次执行,那么使用PreparedStatement对象可能会更高效。

(由于Connection和Statement都需要执行close方法,使用try-with-resources的语法可以简化代码书写)

3. 执行SQL语句,并得到结果集

select语句的查询结果存放在ResultSet对象里面。

使用JDBC查询实例:

import java.sql.Connection;
import java.sql.*;public class Main {public static void main(String[] args) {//1. 通过DriverManager来获得数据库连接try (Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/JDBCtest","root","66666");//2. 创建一个用于执行SQL的Statement对象Statement statement = connection.createStatement()){   //注意前两步都放在try()中,因为在最后需要释放资源!//3. 执行SQL语句,并得到结果集ResultSet set = statement.executeQuery("select * from users");//4. 查看结果while (set.next()){//若结果集链表存在下一个结果,则指针移动System.out.println(set.getInt(1)+set.getString(2)+set.getString(3));//按表的每一列输出结果:依次为ID\Name\PassWord}}catch (SQLException e){e.printStackTrace();}
//5. 释放资源,try-with-resource语法会自动帮助我们close}
}

将查询结果映射为对象

将数据库中数据转换为一个实体类来进行操作:

import java.sql.Connection;
import java.sql.*;class Student {Integer sid;String name;String password;public Student(Integer sid, String name, String password) {this.sid = sid;this.name = name;this.password = password;}public void say(){System.out.println("我叫:"+name+",学号为:"+sid+",我的密码是:"+password);}
}public class Main {public static void main(String[] args) {//1. 通过DriverManager来获得数据库连接try (Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/experiment4","root","123456");//2. 创建一个用于执行SQL的Statement对象Statement statement = connection.createStatement()){   //注意前两步都放在try()中,因为在最后需要释放资源!//3. 执行SQL语句,并得到结果集ResultSet set = statement.executeQuery("select * from users");//4. 查看结果while (set.next()){Student student = new Student(set.getInt(1), set.getString(2), set.getString(3));student.say();}}catch (SQLException e){e.printStackTrace();}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/211659.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Shopee本土号封号几率大吗?如何避免封号?被封号了怎么办?

Shopee是近几年热门的电商平台之一,即使越来越多的跨境电商涌现,他的地位在东南亚市场依然占据一席之地,也依旧吸引着需要跨境商家入局。尤其在2023年,在TikTok Shop在印尼被关停之后,留下了大片空白,Shope…

FPGA----ZCU106使用petalinux 2019.1的第一个app开发

1、petalinux在zcu106上的构建参见前文 FPGA----ZCU106使用petalinux 2019.1(全网最详)-CSDN博客文章浏览阅读31次。本文完成了Vivado 2019.1版本下的基于ZCU106的全部linux系统移植https://blog.csdn.net/qq_37912811/article/details/1345197352、我们…

Modbus RTU协议及modbus库函数使用

一、与Modbus TCP的区别 在一般工业场景使用modbus RTU的场景还是更多一些,modbus RTU基于串行协议进行收发数据,包括RS232/485等工业总线协议。 与modbus TCP不同的是RTU没有报文头MBAP字段,但是在尾部增加了两个CRC检验字节(CRC…

【C++】Cmake使用教程(看这一篇就够了)

文章目录 引言一 环境搭建二 简单入门2.1 项目结构2.2 示例源码2.3 运行查看 三 编译多个源文件3.1 在同一个目录下有多个源文件3.1.1 简单版本3.1.1.1 项目结构3.1.1.2 示例代码3.1.1.3 运行查看 3.1.2 进阶版本3.1.2.1 项目结构3.1.2.2 示例源码3.1.2.3 运行查看 3.2 在不同目…

Visual studio的安装教程2022最新版(图文详细)新手小白C语言软件的安装

目录 1、Visual Studio下载地址 2、工作负荷选择“使用C的桌面开发”和”Visual Studio扩展开发“,安装位置自选 3、下载完成后,点击左上角”文件“->”新建“->”项目“->”空项目“ 4、找到解决方案资源管理器的“头文件”,右键…

Visio学习笔记

1. 常用素材 1.1 立方体:张量, tensor 操作路径:更多形状 ⇒ 常规 ⇒ 基本形状 自动配色 在选择【填充】后Visio会自动进行配色;

Git本地库操作

对本地库的操作很少,我们学习1~6节即可,其他了解下。我们可以在idea中完成对本地库还有远程库的操作,可视化界面用起来更加舒适而且也不会混淆。 1. Git概述 Git 是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小…

飞翔的小鸟小游戏

主类 package APP;import 框架.GameFrame;public class GameApp {public static void main(String[] args) {//游戏的入口new GameFrame();} }场景实物 package 框架;import 图导.Constant; import 图导.GameUtil;import java.awt.*; import java.awt.image.BufferedImage; …

【腾讯云云上实验室-向量数据库】Tencent Cloud VectorDB在实战项目中替换Milvus测试

为什么尝试使用Tencent Cloud VectorDB替换Milvus向量库? 亮点:Tencent Cloud VectorDB支持Embedding,免去自己搭建模型的负担(搭建一个生产环境的模型实在耗费精力和体力)。 腾讯云向量数据库是什么? 腾…

C++的new / delete 与 C语言的malloc/realloc/calloc / free 的讲解

在C语言中我们通常会使用malloc/realloc/calloc来动态开辟的空间,malloc是只会开辟你提供的空间大小,并不会初始化内容;calloc不但会开辟空间,还会初始化;realloc是专门来扩容的,当你第一次开辟的空间不够用…

Javascript每天一道算法题(十四)——合并数组区间_中等

文章目录 1、问题2、示例3、解决方法(0)方法0——双指针(错误思路)(1)方法1——双指针(正确) 总结 1、问题 以数组 intervals 表示若干个区间的集合,其中单个区间为 inte…

[点云分割] 基于法线差的分割

效果: 总体思路: 1、计算DoN特征 2、依据曲率进行过滤 3、依据欧式距离进行聚类 计算DoN特征的目的是为了提供准确的曲率信息。 其他: 计算DoN特征,这个算法是一种基于法线差异的尺度滤波器,用于点云数据。对于点…