后端开发——jdbc的学习(一)

上篇结束了Mysql数据库的基本使用,本篇开始对JDBC进行学习总结,开始先简单介绍jdbc的基本使用,以及简单的练习;后续会继续更新!以下代码可以直接复制到idea中运行,便于理解和练习。

JDBC的概念
JDBC(Java DataBase Connectivity:java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系型数据库提供统一访问,它是由一组用Java语言编写的类和接口组成的。
JDBC的作用:可以通过java代码操作数据库
JDBC的本质
JDBC实质上是java官方提供的一套规范(接口)。用于帮助开发人员快速实现不同关系型数据库的连接!

代码一:

import com.mysql.cj.jdbc.Driver;
import java.sql.*;
//TODO 简单练习感受jdbc:
public class data_test1 {public static void main(String[] args) throws SQLException {//1.注册驱动:DriverManager.registerDriver(new Driver());//2.获取连接:(桥梁)// java程序需要和数据库建立连接; 需要调用getConnection方法,并且需要填入连接数据库的基本信息:数据库ip地址,数据库端口号;账号;密码;连接数据库的名称;//该方法第一个参数:url;第二个参数:username;第三个参数:password;Connection connection = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/atguigudb", "root", "dir99");//3.创建statement(创建将sql语句传入mysql的载具)Statement statement=connection.createStatement();//4.发送sql语句,并且获取返回结果:String sql="select *from jobs;";ResultSet resultSet = statement.executeQuery(sql);//5.将结果进行解析://先看看有没有下一行数据,有就可以获取:while(resultSet.next()){String job_id = resultSet.getString("job_id");String job_title = resultSet.getString("job_title");int min_salary = resultSet.getInt("min_salary");int max_salary = resultSet.getInt("max_salary");System.out.println(job_id+"  "+job_title+"  "+min_salary+"  "+max_salary);}//6.关闭资源:resultSet.close();statement.close();connection.close();}
}

代码二:

import java.sql.*;
import java.util.Scanner;
//TODO 正式使用jdbc:
//查询对应的id号的数据,statement载具,有点缺陷:
public class data_test2 {public static void main(String[] args) throws Exception {//获取用户输入信息Scanner scan=new Scanner(System.in);System.out.println("请输入房间id号:");String department_id=scan.next();System.out.println("请输入位置id号:");String location_id=scan.next();//1.注册驱动://注意像之前那个方法,有问题:其实是注册了两次驱动,1.DriverManager.registerDriver()方法本身会注册一次;// 2.Driver.static{DriverManager.registerDriver()},在这个静态代码块中还会执行一次,因为只要类加载静态代码块就会执行;//解决:只想注册一次驱动:只触发静态代码块://对于触发静态代码块:类加载机制:类的加载时刻,会触发静态代码块;有三个步骤:加载(class文件->jvm虚拟机的class对象);连接(验证(检查文件类型)->准备(静态变量默认值)->解析(触发静态代码块));初始化(静态属性赋真实值)//触发类加载:new关键字;调用静态方法;调用静态属性;反射;子类触发父类;所以从这几种中选择一个最合适的;//此处可以选择反射来注册驱动;Class.forName("com.mysql.jdbc.Driver");//此处参数是字符串,后面可以在配置文件中写入然后解析到这里,更改比较方便灵活;//2.获取连接://对于getConnection方法来说有三种不同的方法(重载);// 传入的参数为:1.数据库软件所在的主机ip地址;2.数据库所在的主机的端口号;3.连接的具体库;4.连接的账号;5.连接的密码://一、对于三个参数的getConnection方法: 1.String url:数据库所在的信息:具体语法:jdbc:mysql://127.0.0.1:3306/atguigudb;// 2.String user数据库的账号:root;3.String password:数据库的密码:dir99;//二、对于两个参数的方法:1.Connection connection = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/atguigudb","root","dir99");//3.创建发送sql语句的statement对象:statement可以发送sql语句到数据库,并且可以获得返回结果;Statement statement = connection.createStatement();//4.发送sql语句:(编写sql语句,发送sql语句):/*对于sql分类:DDL(容器创建,修改,删除)DML(插入、修改、删除)DQL(查询)DCL(权限控制)TPL(事务控制语言)有两种方法:返回值为int类型的:适合非DQL;1.情况一执行DML 返回影响的行数:例如:插入两条数据,返回值为2;删除三条数据,返回值为3;2.情况二非DML 返回值为0;返回值为ResultSet类型的,结果封装对象;适合DQL;也就是说查询调用Query非查询调用Update;*///下面这种sql语句拼接方式复杂,而且容易注入攻击,因此一般不用这种方法:data_test3中进行了更改,用新的方式:String sql="select * from departments where department_id='"+department_id+"'and location_id='"+location_id+"';";//int类型的方法:int i = statement.executeUpdate(sql);//对于查询语句,用返回值为ResultSet类型的;ResultSet resultSet=statement.executeQuery(sql);//5.查询结果集解析://获取数据解析,移动游标获取数据行,然后获取对应行的列数据即可;采用next()方法移动光标,返回类型为boolean类型;// 初始指向第一行数据之前,然后next一下指向下一行,如果有数据返回true,没有返回false;//移动光标之后需要获取对应行的列数据:resultSet.get类型(String columLable|int columIndex);columLable:列名,如果有别名,可以写别名;columIndex:列的下角坐标,从左向右,从1开始,注意和数组区别;while(resultSet.next()){int depart_id=resultSet.getInt(1);String name=resultSet.getString("department_name");int manager_id=resultSet.getInt("manager_id");int locat_id=resultSet.getInt(4);System.out.println(depart_id+"--"+name+"--"+manager_id+"--"+locat_id);}resultSet.close();statement.close();connection.close();}
}

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

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

相关文章

【深度学习-基础学习】Transformer 笔记

本篇文章学习总结 李宏毅 2021 Spring 课程中关于 Transformer 相关的内容。课程链接以及PPT:李宏毅Spring2021ML这篇Blog需要Self-Attention为前置知识。 Transfomer 简介 Transfomer 架构主要是用来解决 Seq2Seq 问题的,也就是 Sequence to Sequence…

ntp校时服务器、ntp授时服务器、ntp时钟服务器

ntp校时服务器、ntp授时服务器、ntp时钟服务器 ntp校时服务器、ntp授时服务器、ntp时钟服务器 三者都是利用NTP技术来实现时间同步服务的一种电子科技产品,名称不同功能一样而已、设备采用冗余架构设计,高精度时钟直接来源于北斗、GPS系统中各个卫星的原…

web前端——clear可以清除浮动产生的影响

clear可以解决高度塌陷的问题&#xff0c;产生的副作用要小 未使用clear之前 <!DOCTYPE html> <head><meta charset"UTF-8"><title>高度塌陷相关学习</title><style>div{font-size:50px;}.box1{width:200px;height:200px;backg…

JavaScript:html获取url参数

使用場景&#xff1a;常用在分享页面 1、采用正则表达式获取地址栏参数 function getQueryString(name) {var reg new RegExp("(^|&)" name "([^&]*)(&|$)", "i" );var r window.location.search.substr(1).match(reg);if (r…

【已解决】打印PDF文件,如何跳过不需要的页面?

打印PDF文件的时候&#xff0c;有时候我们只需要打印其中的几页&#xff0c;并不需要全部打印&#xff0c;那如何在打印时跳过那些不需要的页面呢&#xff1f;不清楚的小伙伴一起来看看吧&#xff01; 如果你是通过网页打开PDF文件&#xff0c;那么可以在页面中找到并点击“打…

[每周一更]-(第53期):Python3和Django环境安装并搭建Django

Python和Django 的安装 Python和Django 兼容情况 django 1.11.x python 2.7 3.4 3.5 3.6 LTS python 目前在用版本 Python 3.6.5 2018-03-28 更新Python 2.7.15 2018-05-01 更新Python 2.7.5 2013-05-12 更新 python和python3安装pip 同时安装上 python2.7.18、python3.11…

如何用 GPT 去分析Excel数据

背景 需要尝试分析 Excel 的内容&#xff0c;每月都需要进行相关的分析&#xff0c;固定化流程&#xff0c;因此尝试制作固化的脚本&#xff0c;方便后续的分析。 执行步骤 帮我写一段 python 代码&#xff0c;我需要区分一个.xlsx的数据。格式示例如下&#xff1a; ”这块自…

mysql创建数据库和表

要在MySQL中创建数据库和表&#xff0c;可以按照以下步骤进行操作&#xff1a; 连接到MySQL服务器&#xff1a; mysql -u username -p其中&#xff0c;username 是你的MySQL用户名。执行上述命令后&#xff0c;系统会提示你输入密码&#xff0c;输入密码后即可登录到MySQL服务…

c语言结构体学习上篇

文章目录 前言一、结构体的声明1&#xff0c;什么叫结构体?2&#xff0c;结构体的类型3,结构体变量的创建和初始化4&#xff0c;结构体的类型5&#xff0c;结构体的初始化 二、结构体的访问1&#xff0c;结构体成员的点操作符访问2&#xff0c;结构体体成员的指针访问 前言 昨…

用户管理第2节课--idea 2023.2 后端--实现基本数据库操作(操作user表) -- 自动生成 --【本人】

一、插件安装 1.1 搜索插件 mybatis 安装 1.2 接受安装 1.3 再次进入&#xff0c;说明安装好了 1.4 与鱼皮不同点 1&#xff09;mybatis 版本不一致 鱼皮&#xff1a; 本人&#xff1a; 2&#xff09;鱼皮需重启安装 本人不需要 1.5 【需完成 三、步骤&#xff0c;再来看】 …

AI发展将来对人力市场有什么影响

#AI发展将来对人力市场有什么影响 #合同智能审查、合同要素智能提取、合同版本对比、合同智能起草、文本一致性对比、广告审查、合同范本库 人工智能的发展对人们的日常生活起到至关重要的作用&#xff0c;智能发展也是涉猎众多领域&#xff0c;人工智能技术对于企业法务管理…

Git - 强制替换覆盖 master 分支解决方案

问题描述 在版本迭代中&#xff0c;通常会保持一个主分支 master&#xff0c;及多个 dev 分支&#xff0c;但是因为 dev 分支的开发周期过长&#xff0c;迭代太多而没有及时维护 master &#xff0c;导致后来发版上线的大部分代码都在 dev 分支上&#xff0c;如果将代码在 mas…

LiveGBS流媒体平台GB/T28181功能-用户管理通道权限管理关联通道支持只看已选只看未选添加用户备注角色

LiveGBS功能用户管理通道权限管理关联通道支持只看已选只看未选添加用户备注角色 1、用户管理2、添加用户3、关联通道3.1、只看已选3.2、只看未选 4、自定义角色5、搭建GB28181视频直播平台 1、用户管理 LiveGBS支持用户管理&#xff0c;添加用户&#xff0c;及配置相关用户权…

promise.prototype.finally重写和兼容火狐低版本浏览器

一、finally()方法用于指定不管 Promise 对象最后状态如何&#xff0c;都会执行的操作。该方法是 ES2018 引入标准的 let promise new Promise() promise .then(result > {}) .catch(error > {}) .finally(() > {})finally方法的回调函数不接受任何参数;finally方法…

element-ui Tree 树形控件 过滤保留子级并获取过滤后的数据

本示例基于vue2 element-ui element-ui 的官网demo是只保留到过滤值一级的&#xff0c;并不会保留其子级 目标 1、Tree 树形控件 保留过滤值的子级 2、在第一次过滤数据的基础上进行第二次过滤 先看效果 Tree 树形控件 保留过滤值的子级 <el-treeclass"filter-t…

直观从零理解 梯度下降(Gradient descent) VS 随机梯度下降 (Stochastic gradient descent) 函数优化

首发于Data Science 单变量微分(Differentiation) 常用基本微分有&#xff1a; 四则运算法则&#xff1a; 链式法则(Chain-rule) 极大值(maxima)与极小值(minima) 向量微分 梯度下降(Gradient descent):几何直觉 学习率&#xff08;Learning Rate&#xff09;的直观理解…

笔记中所得(已删减)

1.交流电的一个周期内电压/电流的平均值都为0 2.电动势:电池将单位正电荷由负极搬到正极所做的功 5.额定能量:电池的额定容量乘以标称电压,以Wh为单位 6.500mAh意义是可以以500mA的电流放电1小时 7.电池容量的单位是mAh 13.实际电流源不能串联 14. 15. 16. 17. 18. 19.电…

C++ 二进制图片的读取和blob插入mysql_stmt_init—新年第一课

关于二进制图片的读取和BLOB插入一共包含五步 第一步&#xff1a;初始化 MYSQL_STMT* stmt mysql_stmt_init(&mysql); 第二步&#xff1a;预处理sql语句 mysql_stmt_prepare(stmt,sql,sqllen); 第三步&#xff1a;绑定字段 mysql_stmt_bind_param(stmt,bind); 第四…

判断上、下三角矩阵

题目&#xff1a; 给定一个三角矩阵&#xff0c;判断其是否为&#xff1a;上三角矩阵、下三角矩阵。 上三角矩阵指主对角线以下的元素都为0的矩阵&#xff1b; 下三角矩阵指主对角线以上的元素都为0的矩阵&#xff1b; 主对角线为从矩阵的左上角至右下角的连线。 输入矩阵是…

前端八股文(HTML篇)二

目录 1.说一下web worker 2.iframe有哪些优点和缺点 3.label的作用是什么&#xff1f;如何使用&#xff1f; 4.script标签中defer和async的区别 5.Canvas和SVG的区别 6.head标签有什么作用&#xff0c;其中什么标签必不可少&#xff1f; 7.浏览器是如何对HTML5的离线储存…