MySql Jdbc

sql 复制代码
import com.mysql.jdbc.Driver;

import java.sql.*;

public class JdbcFirstDemo {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //1.加载驱动
        Class.forName("com.mysql.cj.jdbc.Driver");  //固定写法

        //2.用户信息和url  jdbcstudy是数据库名
         String url = "jdbc:mysql://localhost:3306/jdbcstudy?useUnicode=true&characterEncoding=utf8&useSSL=False";
         String username="root";
         String password="123456";

        //3.连接成功
        Connection connection = DriverManager.getConnection(url,username,password);

        //4.执行SQL的对象
        Statement statement = connection.createStatement();

        //5.执行SQL
         String sql = "SELECT * FROM users";
        ResultSet resultSet = statement.executeQuery(sql);
        while(resultSet.next()){
            System.out.println("id=" + resultSet.getObject("id"));
            System.out.println("name=" + resultSet.getObject("NAME"));
            System.out.println("pwd=" + resultSet.getObject("PASSWORD"));
            System.out.println("email=" + resultSet.getObject("EMAIL"));
            System.out.println("birth=" + resultSet.getObject("BIRTHDAY"));

        }
        //6.释放连接
        resultSet.close();
        connection.close();
        statement.close();
    }
}
复制代码
关于statement: 用于像数据库发送SQL语句
        statement.executeUpdate();//更新 插入 删除 都是用这个 返回一个受影响的行数
        statement.executeQuery(); //查询操作 返回一个ResultSet

ResultSet:查询的结果集:封装了所有的查询结果

拿到结果

复制代码
resultSet.getObject();
resultSet.getString();
resultSet.getInt();
resultSet.getDate();
resultSet.getFloat();

resultSet.next();移动到下一个数据

使用IDEA连接数据库:

找到IDEA右边的database 在这里点+即可

数据库连接池

数据库连接--执行完毕--释放

连接00释放 十分浪费系统资源

池化技术:准备一些预先的资源,过来就连接预先准备好的

最小连接数: 一般和常用连接数量一样

最大连接数: 业务最高承载上限

超过最大连接数要排队等待

等待超时:超过时间则报错

编写连接池 ,实现一个接口 DataSource

相关推荐
啦啦啦_999910 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同76511 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码11 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean11 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
那个村的李富贵11 小时前
解锁CANN仓库核心能力:50行代码搭建国产化AIGC图片风格迁移神器
mysql·信息可视化·aigc·cann
小Tomkk11 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
qq_124987075311 小时前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
游戏开发爱好者812 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
王码码203512 小时前
Flutter for OpenHarmony 实战之基础组件:第三十一篇 Chip 系列组件 — 灵活的标签化交互
android·flutter·交互·harmonyos
黑码哥12 小时前
ViewHolder设计模式深度剖析:iOS开发者掌握Android列表性能优化的实战指南
android·ios·性能优化·跨平台开发·viewholder