开开心心带你学习MySQL数据库之节尾篇

请添加图片描述

Java的JDBC编程

各种数据库,MySQL, Oracle, SQL Server在开发的时候,就会提供一组编程接口(API)
API ~~ Application Programming Interface ~~ 应用程序编程接口
计算机领域里面的一个非常常见的概念,
给你个软件,你能对他干啥(从代码层次上的)
基于它提供的这些功能,就可以写一些其它代码了(好抽象啊!)

例子:

image-20230910194247740

函数(function) => C语言和方法(method) => Java 有什么区别??
没区别~~ 很多时候,这两个词都是混用的~~ 严格意义的讲,是有区别,区别不大
本质上都是一个可以执行可以复用的代码片段~

JDBC的由来

MySQL, Oracle, SQL Server这些数据库提供的API是不相同的
原因: 有人的地方,就有江湖.MySQL, Oracle, SQL Server分别是由三个不同的团队开发的,出现了三份不同的API,导致身为程序猿的我们不得不学多份API,学习成本就变高了
这时,一个江湖地位非常重的大佬(Java )就来从中调节来了,
Java就提出来了一套API接口标准,要求其它厂商对照着这个标准来实现API,当然其它厂商的原生API并不用进行大幅度修改,只是写点代码,对其进行包装,包装成符合Java提出的这套API标准就行了 => 从今以后,Java程序猿只要学习这一套风格的API就够了~~ 不管换成什么的数据库,底层的东西怎么变,上层的东西即程序猿写的代码都是一样的 => 降低了程序猿的学习负担
java提出的这套API的名字就叫JDBC
JDBC,它为Java 开发人员操作数据库提供了一个标准的API,可以为多种关系数据库提供统一访问.

image-20230910215228119

Java程序猿要想进行数据库开发就需要在自己的项目中导入对应数据库的驱动包,才能编写代码
平时经常会见到硬件的驱动,硬件的驱动是让操作系统认识新的硬件设备,数据库的驱动是让JDBC能认识数据库的API

驱动包从哪里来?

~~ 数据库厂商提供的
1.mysql 的官方网站获取
~~ 下策 = > mysql被oracle 收购之后,官网也合并了,变成了oracle官网的一个子页面,而oracle的官网是一个非常难用的官网:
(1)找东西一点都不好找,不知道在那个角落藏着
(2)动不动的就要进行登录认证,对登录的账号密码要求还高,密码忘了找回也麻烦.
2.github => 开源的项目一般在它上面都会有代码的,这个在上面是找得到的
3.maven的中央仓库
maven => 相当于手机上的应用商店
中央仓库 => 托管了各种软件程序包的服务器
通过应用商店,就可以访问到软件程序包,下载下来
image-20230910232444068

image-20230910233329604

image-20230911000202934

jar包 => java 发布程序的典型方式.
java 通过 java 源文件编译成 .class 文件,jvm来解释执行.class每个java 都对应一个.class
如果代码里java 非常多呢??
把一大堆的.class给打成压缩包(类似于.rar.zip),此处的压缩包为.jar ~~ 一个.jar里面就包含很多很多.class文件~~ 把jar包拷贝给对方,对方就可以直接使用jvm 来运行了
此处, mysql驱动包的这个jar包不是单独运行的jar包,可以把它导入到咱们的项目然后就可以调用其中的方法和类来进行编程了!!!

黑客想入侵你的电脑也没那么容易,windows自带的杀毒软件已经很厉害了 => Windows安全中心
当然,如果你实在想访问一些未知网站,建议在电脑上装一个虚拟机软件,在虚拟机里面装一个虚拟的操作系统,通过虚拟机软件里面构造的虚拟主机来访问,就算黑客入侵,入侵的也是你的虚拟机 ~~ 到时候,虚拟机删了重新创一个就行了 ~~ 小技巧

如何导入数据库驱动包
  1. 在IDEA创建个Java项目

  2. 在项目里创建一个目录(New Directory)lib ~~ 复制jar包,粘贴进lib目录

  3. 右键lib,选择点击Add as library => 目的就是把这个lib目录标记成项目的库,idea就能识别这个目录里的jar包从而就可以调用里面的类来写代码了
    注:每次创建一个项目都得这样做

  4. 编写JDBC代码 ~~ 以插入为例
    在src中创建一个JDBCInsert.java文件

    public class JDBCInsert {public static void main(String[] args) throws SQLException {//JDBC 需要通过一下步骤来完成开发//1. 创建并初始化一个数据源DataSource dataSource = new MysqlDataSource();//向上转型~~父类引用指向子类对象((MysqlDataSource) dataSource).setURL("jdbc:mysql://127.0.0.1:3306/fly?characterEncoding=utf8&useSSL=false");//设置URL((MysqlDataSource) dataSource).setUser("root");//设置用户名 ~~ 用户名都是root(默认就是root)((MysqlDataSource) dataSource).setPassword("0213");//设置密码 ~~ 安装数据库的时候密码是什么就写什么//这几个东西都设置进去,才能够访问数据库服务器 //~~ 并且这个代码只是设置数据源,描述数据库服务器在哪//~~还没真正和数据库服务器连接呢!!/*(注意,上述代码,不使用向上转型,向下转型,就直来直去的写,也可以!!没有任何问题)(C++的风格),之所以向上面这么写,完全是因为Java这个圈子里,流行这么写代码如下:MysqlDataSource dataSource = new MysqlDataSource();dataSource.setURL();*///2.和数据库服务器建立连接Connection connection = dataSource.getConnection();//3.构造SQL语句String sql = "insert into student value(1, 'fly')";PreparedStatement statement = connection.prepareStatement(sql);//4.执行SQL语句int ret = statement.executeUpdate();System.out.println("ret = " + ret);//把sql语句(预编译过的)发送给数据库服务器,由服务器做出响应//5.释放必要的资源statement.close();connection.close();}
    }
    
    1. 运行代码,查看运行结果,并在mysql客服端进行查看,再次验证是否成功
    对上述代码的部分理解

    数据源 => 数据从哪里来,描述数据库服务器在哪里 ~~ DataSource,一个接口,JDBC提供给我们的一个API

    setURL:这个方法,是子类有的,父类没有的方法,要想使用,就需要把父类引用转回成子类引用~~(向下转型)

    URL:计算机里的一个常见术语,唯一资源定位符 ~~ 描述网络上的某个资源所在的位置 ~~ 格式非常有特点!!

    jdbc:mysql://127.0.0.1:3306/fly?characterEncoding=utf8&useSSL=false
    jdbc => 固定的
    mysql => 看你用的是什么数据库

    IP地址127.0.0.1 => mysql 数据库是一个"客户端服务器"结构的程序,客户端和服务器之间通过网络来通信 ~~ 网络上确定主机的位置就是通过IP地址来确定的 ~~ 127.0.0.1叫做环回IP,表示你自己的当前主机,因为咱们的数据库客户端(现在写的jdbc代码),数据库服务器(之前装存数据的服务)是在一个主机上~~ 当然,客户端和服务器在不同主机上,IP就得另写

    3306 => 端口号 ,端口用来区分应用程序,当前数据库服务器默认端口就是3306
    fly => 创建的数据库名 ~~ create database 数据库名;
    ? 号后面表示参数 => characterEncoding=utf8 ~~ 字符集使用utf-8, useSSL=false ~~ SSL是个加密协议,此处false表示不加密

    dataSource.getConnection();
    受查异常必须要显式处理,非受查异常不显式处理也没事
    如果你,流鼻涕,打喷嚏,咳嗽,时间放到没发生新冠的时候,是异常,但不用特别处理,过几天凭自身免疫力就好了 ~~ 非受查异常
    如果你,发烧在新冠期间,就赶紧测个核酸,必须赶紧隔离~~ 受查异常

    使用PreparedStatement提前预编译一下这个SQL字符串
    如果请求是个SQL 字符串,服务器是可以处理的.服务器就需要对SQL进行解析,理解这里的含义并执行
    ~~ 如果有几万个客户端都在发这个请求,对于服务器的压力就比较大了!!
    ~~ 让客户端来对SQL进行预编译,服务器做的工作就简单一些,压力就会小不少.好比学校食堂,要求同学吃完饭,自己把盘子送到回收处

    executeUpdate=> 返回 int 表示影响到的行数

    即使咱们使用代码来操作数据库,还是靠 sqI 语句!
    只不过是换成用代码来构造 sql
    前面 sql的各种语法仍然有效!!

    上面的代码,看起来麻烦,实际上非常简单 ~~
    这里的代码刚开始接触,会觉得很麻烦,涉及到很多新的类,新的方法,新的概念新的参数…
    但是多写几次就发现,这里的代码就是固定套路
    正因为如此,实际开发中,就会使用一些框架来简化数据库操作代码 ~~ MyBatis这样的框架就是如此 ~~
    光会框架是不行的,还得知道框架背后的操作,对原生的JDBC有足够的理解
    框架是一直在变的,但JDBC 是不变的!!!
    程序猿是不是吃青春饭?因为新的技术层出不穷
    ~~ 后浪拍死前浪了呀 ~~ 只有多掌握这些不变的,就能以不变,应万变

恋爱小技巧

~~ 和妹子说晚安,不要打晚安二字,而是打拼音wanan,
这么做的原因是wanan => 我 爱你 爱你
学到了没有兄弟们,这多浪漫啊!!!(*^▽^*)

注:该篇文章存在一些花絮待完善!!!

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

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

相关文章

【MySQL】表的操作

目录 MySQL表的操作 创建表 创建表案例 查看表结构 修改表 删除表 MySQL表的操作 表操作至少会涉及如下两类SQL语句: DDL(Data Definition Language)数据定义语言:比如建表、删表、该表、新增列、删除列等。DML&#xff08…

JavaWeb_LeadNews_Day11-KafkaStream实现实时计算文章分数

JavaWeb_LeadNews_Day11-KafkaStream实现实时计算文章分数 KafkaStream概述案例-统计单词个数SpringBoot集成 实时计算文章分值来源Gitee KafkaStream 概述 Kafka Stream: 提供了对存储与Kafka内的数据进行流式处理和分析的功能特点: Kafka Stream提供了一个非常简单而轻量的…

星际争霸之小霸王之小蜜蜂(十二)--猫有九条命

系列文章目录 星际争霸之小霸王之小蜜蜂(十一)--杀杀杀 星际争霸之小霸王之小蜜蜂(十)--鼠道 星际争霸之小霸王之小蜜蜂(九)--狂鼠之灾 星际争霸之小霸王之小蜜蜂(八)--蓝皮鼠和大…

使用navicat for mongodb连接mongodb

使用navicat for mongodb连接mongodb 安装navicat for mongodb连接mongodb 安装navicat for mongodb 上文mongodb7.0安装全过程详解我们说过,在安装的时候并没有勾选install mongodb compass 我们使用navicat去进行可视化的数据库管理 navicat for mongodb下载地址…

系统架构设计师(第二版)学习笔记----系统架构概述

【原文链接】系统架构设计师(第二版)学习笔记----系统架构概述 文章目录 一、系统架构的定义与发展历程1.1 架构的定义1.2 架构设计的作用1.3 架构设计产生的背景1.4 软件架构的发展历程1.5 模块化开发方法1.6 模块法方法分解模块遵循的原则1.7 软件工程…

【算法】一文带你从浅至深入门dp动态规划

文章目录 一、前言二、动态规划理论基础1、基本概念2、动态规划五部曲【✔】3、出错了如何排查? 三、实战演练🗡0x00 斐波那契数0x01 第N个泰波那契数0x02 爬楼梯0x03 三步问题0x04 使用最小花费爬楼梯⭐解法一解法二 0x05 解码方法* 四、总结与提炼 一、…

英飞凌TC3xx--深度手撕HSM安全启动(三)--TC3xx HSM系统架构

今天聊TC3xx HSM系统,包括所用内核、UCB相关信息、Host和HSM交互方式。 1、HSM系统架构 下图来源于英飞凌官网培训材料。 TC3xx的HSM内核是一颗32位的ARM Cortex M3,主频可达100MHz,支持对称算法AES128、非对称算法PKC(Public Key Crypto) ECC256、Hash SHA2,以及T…

Python的pandas库来实现将Excel文件转换为JSON格式的操作

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…

2023 CCF国际AIOps挑战赛,报名倒计时!|截止时间9月15日

智能运维领域最具影响力的专业赛事——2023 CCF国际AIOps挑战赛,自报名启动以来已收到230余支队伍报名,约600余位选手参与本次挑战赛。本次大赛的报名截止时间为9月15日,目前报名已经进入倒计时,请选手们抓紧最后时间报名参赛&…

2023高教社杯数学建模A题思路分析 - 定日镜场的优化设计

# 1 赛题 A 题 定日镜场的优化设计 构建以新能源为主体的新型电力系统, 是我国实现“碳达峰”“碳中和”目标的一项重要 措施。塔式太阳能光热发电是一种低碳环保的新型清洁能源技术[1]。 定日镜是塔式太阳能光热发电站(以下简称塔式电站)收集太阳能的基本组件&…

搭建vue3项目并git管理

搭建vue3项目 采用vue3的create-vue脚手架搭建项目,底层是vite,要求环境 node 16.0及以上(node -v检查node版本) 在文件夹右键->终端-> npm init vuelatest,输入项目名称,根据需要选择是否装包 src…

COMO-ViT论文阅读笔记

Low-Light Image Enhancement with Illumination-Aware Gamma Correction and Complete Image Modelling Network 这是一篇美团、旷视、深先院、华为诺亚方舟实验室、中国电子科技大学 五个单位合作的ICCV2023的暗图增强论文,不过没有开源代码。 文章的贡献点一个是…

LabVIEW利用纳米结构干电极控制神经肌肉活动

LabVIEW利用纳米结构干电极控制神经肌肉活动 随着人口老龄化,长期护理的必要性变得更加重要,医疗中心的压力开始达到惊人的水平。全球对所有社会和经济部门的认识对于更好地协调卫生和社会服务之间的护理以及为更多的院外治疗提供条件至关重要。 关于医…

[管理与领导-85]:IT基层管理者 - 核心技能 - 高效执行力 - 10 - 高效执行力的9个段位

目录 前言: 一段:准确执行,快速反应,坚决执行 (态度很重要) 二段:结果导向 苦劳过后,有功劳(有结果很重要) 三段:有始有终 主动反馈、有始有终…

【C++】day4学习成果:仿写string类等等

1.仿照string类&#xff0c;完成myString 类 代码&#xff1a; #include <iostream> #include <cstring>using namespace std;class myString {private:char *str; //记录c风格的字符串int size; //记录字符串的实际长度public://无参构造myS…

SpringBoot原理-自动配置-原理分析-源码跟踪

自动配置原理 SpringBootApplication 该注解标识在SpringBoot项目的启动类上&#xff0c;是SpringBoot中最为重要的注解&#xff0c;该注解由三个部分组成。 SpringBootConfiguration&#xff1a;该注解与Configuration注解作用一样&#xff0c;用来声明当前类为一个配置类Comp…

VM安装RedHat7虚机ens33网络不显示IP问题解决

1、今天在VMware中安装RedHat7.4虚拟机&#xff0c;网络连接使用的是 NAT 连接方式&#xff0c;刚开始安装成功之后输入ifconfig 还能看到ens33自动分配的IP地址&#xff0c;但是当虚机关机重启后&#xff0c;再查看IP发现原来的ens33网络已经没有了&#xff0c;只变成了这两个…

【大数据】Kafka 入门指南

Kafka 入门指南 1.Kafka 简介2.Kafka 架构3.分区与副本4.偏移量5.消费者组6.总结 1.Kafka 简介 Apache Kafka 是一种高吞吐、分布式的流处理平台&#xff0c;由 LinkedIn 开发并于 2011 年开源。它具有 高伸缩性、高可靠性 和 低延迟 等特点&#xff0c;因此在大型数据处理场景…

Python类的概念

类 类的技术名词解释 ● 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。 ● 类变量&#xff1a;类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用…

CSP 201312-1 出现次数最多的数

答题 用两个map&#xff0c;一个map记录每个数出现的次数并降序排序&#xff0c;另一个map将次数作为键&#xff0c;数本身作为值&#xff0c;降序排序&#xff0c;搞定 #include<iostream> #include<map> using namespace std; int main(){map<int,int,great…