Java连接数据库

news2024/11/19 13:26:28

数据库

存储数据:集中管理

目的: 文件中的数据能够放在数据库中集中管理

管理方法:一个项目一个库,每个库中包含最小化数据的表

开发: 节省存储空间,节省运行空间,采用数据库,架构

Java连接数据库

Java se所有类String ArrayList来自java.lang

后面web页面应用----à导包,包第三包 jar包

mysql-connector-java.jar 连接数据库的版本 

java面向接口,提供了数据库的相关接口,每个不同的数据库厂家根据接口开发方法。Java使用数据库,调用对应接口的实现。

反射

连接:Connection 连接

在Driver类中connect方法就是数据库连接方法,方法返回类型Connection

Connection接口中方法就是操作数据库的相关方法

Java原生DriverManager,方便程序员开发方便

DriverManager调用Connection, getConnection

调用DriverManager.getConnection(数据库地址,用户名,密码 );

先把mysql-connect-java包导入到idea的库中

首先建一个包

这个package取名lib

把使用的java包拷贝在lib的package目录下。

在项目名称上右键,点击 open Module setting 模块设置。

在出现的对话框中,左侧点击library库,然后右边点击加号,添加这个jar包。

点击加号后,选择java

出现的对话框,选择自己项目下的jar 包文件

这里是一个询问的信息

直接点击ok即可。继续ok即可。

这时项目中的jar包就会解开。

解开后,才知道java包如何导入。

使用代码连接java,再规范化开发(面向接口)

连接java效仿mysql源码,注册驱动。

DriverManager.registerDriver(new Driver());

获取Connection连接接口,因为数据库的操作方法都在这里。

Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/shop","root","admin");

连接时输入mysql 数据库的连接地址。

getConnection输入数据库的连接地址

本地localhost,连接端口号 3306,连接数据库

jdbc:mysql://localhost:3306/shop

用户名 root

密码  admin

通过连接执行sql语句,需要定义sql语句。

String sql="select * from user";

在connection操作数据库前面有两个Statement , ResultSet

 Statement 是执行sql语句的线程。

//Statement进行线程语句的处理

Statement st=conn.createStatement();

Statement是线程语句的处理,statement中可以执行语句

executeQuery执行查询,返回的类型是ResultSet,这是数据库结果记录

executeUpdate执行更新(增删改)

统一方法;execute执行增删改查,返回值是布尔型,不能查询后返回记录的条件(除登录)

如果执行查询,结果返回ResultSet

//查询的方法executeQuery,结果是ResultSet

ResultSet rs=st.executeQuery(sql);

在Resultset中看到next()方法,一定用到Iterator迭代器,这个迭代器可以用next();ResultSet是一个迭代器

只能使用迭代器的方法来使用。返回类型:next()有没有,数据库中把指针移到当前数据。

ResultSet中next方法的原理。

 在ResultSet类中都要get后面跟上类型。因为java 和mysql 都是强语言类型,数据必须指明类型。Java 获取字段类型一定要跟mysql里对应字段类型是一致的。

ResultSet rs=st.executeQuery(sql);

//因为ResultSetnext()判断数据是否有,如果有一直做,执行一次next(),记录在restulSetwhile(rs.next()){

    //按照mysql的类型和java类型对应关系取数据

    int id=rs.getInt("id");

    String name=rs.getString("username");

    String sex=rs.getString("sex");

    String position=rs.getString("position");

    int age=rs.getInt("age");

    String password=rs.getString("password");

    System.out.println(id+":"+name+":"+sex+":"+position+":"+age+":"+password);

}

在数据方法中,Connection中有方法close(),close()关闭。

   这里的问题:

DriverManager.registerDriver(new Driver());

注册Driver时,new Driver中源码中静态块中也发生new Driver()

我们这里的代码执行两次,目的是注册驱动

在源码中,获取连接本身具备

Reflection.getCallerClass()

Reflection类是 反射

通过反射技术注册类

注意:java 只出规范,其他的应用按照规范去开发,java在每一个规范中都有反射去找到相关的类。

直接使用反射技术把驱动注册。

正确连接数据库使用方法
(1)注册驱动(反射)

Class.forName("com.mysql.jdbc.Driver");

(2)获取连接

Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/shop","root","admin");

(3)定义sql语句

String sql="select * from user";

(4)获取Statement

Statement st=conn.createStatement();

(5)根据需要决定,如果查询executeQuer,如果更新executeUpdate

ResultSet rs=st.executeQuery(sql);

返回结果:如果是查询用ResultSet,如果是增删改,返回的是int

如果是ResultSet使用迭代器遍历next()方法

(6)根据mysql的数据类型与java 的数据类型的对应关系,使用对应的get方法,得出结果.

(7)最后依次关闭ResultSet,Statement,Connection。

rs.close();

st.close();

conn.close();

开发:基本的单表增删改查

  1. 面向接口,需要有接口文件

这里的方法:增删改查

一个属性和一个值对应关系(Map,面向对象)

按照java思想理念,面向对象,没有方法是逻辑关系,它就是java bean)

(2) 面向对象,把数据库记录中的字段封装成一个类。

 Java bean在开发中,就是对应的数据库的表

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

windows判断exe应用程序是否在使用的bat脚本

脚本 REM 查询进程是否存在 tasklist|findstr /i "mysqld.exe">nul &&echo y >2.log ||echo n >2.log REM 读取文本内容赋值给变量 set /P resu<2.log if %resu% y (echo process in use ) else (echo process not in use )我们已mysqld.exe…

【算法刷题】Day10

文章目录 15. 三数之和题干&#xff1a;算法原理&#xff1a;1、排序 暴力枚举 利用set 去重2、排序 双指针 代码&#xff1a; 18. 18. 四数之和题干&#xff1a;算法原理&#xff1a;1、排序 暴力枚举 利用set 去重2、排序 双指针 代码&#xff1a; 15. 三数之和 原题链…

利用python连接MySQL数据库并执行相关sql操作

一、新建MySQL数据库 1.启动MySQL服务 打开phpstudy&#xff0c;开启MySQL服务。如果开启失败的话&#xff0c;可以打开任务管理器&#xff0c;把正在运行的mysqld服务的进程进行关闭&#xff0c;再次打开MySQL服务即可启动。 2.新建MySQL数据库 选择数据库&#xff0c;点击…

linux(3)之buildroot配置软件包

Linux(3)之buildroot配置软件包 Author&#xff1a;Onceday Date&#xff1a;2023年11月30日 漫漫长路&#xff0c;才刚刚开始… 参考文档&#xff1a; Buildroot - Making Embedded Linux Easymdev.txt docs - busybox - BusyBox: The Swiss Army Knife of Embedded Linu…

Elasticsearch分词器--空格分词器(whitespace analyzer)

介绍 文本分析&#xff0c;是将全文本转换为一系列单词的过程&#xff0c;也叫分词。analysis是通过analyzer(分词器)来实现的&#xff0c;可以使用Elasticearch内置的分词器&#xff0c;也可以自己去定制一些分词器。除了在数据写入时将词条进行转换&#xff0c;那么在查询的时…

记一次SQL Server磁盘突然满了导致数据库锁死事件is full due to ‘LOG_BACKUP‘.

背景 最近我们的sql server 数据库磁盘在80左右&#xff0c;需要新增磁盘空间。还是处以目前可控的范围内&#xff0c;但是昨天晚上告警是80%&#xff0c;凌晨2:56分告警是90%&#xff0c;今天早上磁盘就满了。 经过 通过阿里云后台查看&#xff0c;磁盘已经占据99%&#xff0c…

Spring @Cacheable缓存注解

一、简介 缓存介绍 缓存&#xff0c;在我们的日常开发中用的非常多&#xff0c;是我们应对各种性能问题支持高并发的一大利器。 Spring 从 3.1 开始就引入了缓存的支持。定义了如下两个接口来统一支持不同的缓存技术。 org.springframework.cache.Cacheorg.springframework.ca…

uniapp中解决swiper高度自适应内容高度

起因&#xff1a;uniapp中swiper组件swiper 标签存在默认高度是 height: 150px &#xff1b;高度无法实现由内容撑开&#xff0c;在默认情况下&#xff0c;swiper盒子高度显示总是 150px 解决办法思路&#xff1a; 动态设置swiper盒子的高度&#xff0c;故需要获取swiper-item盒…

展锐平台回读分区

展锐平台回读分区 1. 回读分区意义2. 操作步骤3. 回读存放的位置 1. 回读分区意义 回读的分区可用作备份&#xff0c;还可将回读到的分区与烧入机器版本的分区进行比较&#xff0c;如果两者不一致则说明烧录出现问题&#xff0c;需要重新烧录。 2. 操作步骤 打开展锐烧录工…

深度解析 Dockerfile:构建可重复、可扩展的Docker镜像

文章目录 什么是Dockerfile&#xff1f;Dockerfile的基本结构常用Dockerfile指令解析1. FROM2. LABEL3. WORKDIR4. COPY5. RUN6. EXPOSE7. ENV8. CMD 构建可重复、可扩展的Docker镜像1. 指定基础镜像的版本2. 合理使用缓存3. 精简镜像4. 使用多阶段构建 总结 &#x1f388;个人…

UDS诊断服务简单介绍

UDS简单介绍 &#xff08;1&#xff09;UDS&#xff08;Unified Diagnostic Service&#xff0c;统一诊断服务&#xff09;&#xff0c;诊断协议是ISO 15765和ISO 14229定义的一种汽车通用诊断协议&#xff0c;位于OSI模型中的应用层&#xff0c;可在不同的汽车总线&#xff0…

大势智慧荣获2023光合组织解决方案大赛人工智能赛道标杆奖及争先奖!

近日&#xff0c;2023年第三届光合组织解决方案大赛获奖名单正式公布。大势智慧以基于国产化平台的实景三维全流程解决方案&#xff0c;突破层层选拔&#xff0c;最终荣获“集智计划”&#xff08;人工智能赛道&#xff09;标杆奖及争先奖。 实景三维是我国的数字基础设施&…

零售数字化“逆熵”的6项原则和8种能力建设|ShopeX徐礼昭

作者&#xff1a;徐礼昭 来源&#xff1a;《三体零售逆熵法则》节选 旧的规则与秩序被打破&#xff0c;无序成为常态 新时代洪流裹挟冲击着传统零售 无序带来的“熵增”侵蚀企业生命 所有人都在不确定性中寻找确定 数字化如何助力企业铸就「反熵增」神器&#xff1f; 如何…

Android 滑动按钮(开关) SwitchCompat 自定义风格

原生的SwitchCompat控件如下图&#xff0c;不说不堪入目&#xff0c;也算是不敢恭维了。开个玩笑... 所以我们就需要对SwitchCompat进行自定义风格&#xff0c;效果如下图 代码如下 <androidx.appcompat.widget.SwitchCompatandroid:id"id/switch_compat"android:…

Python | 轻量ORM框架Peewee的基础使用(增删改查、自动创建模型类、事务装饰器)

文章目录 01 简介02 安装03 自动创建模型类04 基础使用4.1 查询4.2 新增4.3 更新4.4 删除 05 事务 01 简介 在使用python开发的过程中&#xff0c;有时需要一些简单的数据库操作&#xff0c;而Peewee正是理想的选择&#xff0c;它是一个小巧而灵活的 Python ORM&#xff08;对…

附录A 指令集基本原理

1. 引言 本书主要关注指令集体系结构4个主题&#xff1a; 1. 提出对指令集进行分类的方法&#xff0c;并对各种方法的优缺点进行定性评估&#xff1b; 2. 提出并分析一些在很大程度上独立于特定指令集的指令集评估数据。 3. 讨论语言与编译器议题以及…

Python+Requests模块获取响应内容

Requests模块获取响应内容 响应包括响应行、响应头、响应正文内容&#xff0c;这些返回的响应信息都可以通过Requests模块获取。这些 获取到的响应内容也是接口测试执行得到的实际结果。 获取响应行 获取响应头 获取其它响应信息 代码示例&#xff1a; # 导入requests模块…

《微信小程序开发从入门到实战》学习三十八

4.2 云开发JSON数据库 4.2.9 条件查询与查询指令 在查询数据时&#xff0c;有时需要对查找的数据添加一些限定条件&#xff0c;只获取满足给定条件的数据&#xff0c;这样的查询称为条件查询。 可以在集合引用上使用where方法指定查询条件&#xff0c;再用get方法&#xff0…

python可视化之——seaborn简单图绘制指南

0. 主要内容 该笔记主要包括常见的&#xff1a;散点&#xff0c;折线&#xff0c;box&#xff0c;violin&#xff0c;等图的绘制&#xff0c;可以帮助我们了解数据存在的变量之间的某种关系或者数据趋势。在日常工作中&#xff0c;我们可以进行简单的数据分析和可视化&#xff…

Flutter基础开发

参考:http://bbs.itying.com/topic/5cdb83b7fac8b00944a7a0c3 参考:https://www.bilibili.com/video/BV1S4411E7LY?p34&spm_id_frompageDriver 1.使用镜像 由于在国内访问Flutter有时可能会受到限制&#xff0c;Flutter官方为中国开发者搭建了临时镜像&#xff0c;大家可以…