Java JDBC篇1——初识JDBC

Java JDBC篇1——初识JDBC

Java DataBase Connectivity Java 数据库连接(Java语言操作数据库)

1、什么是JDBC

其实是官方定义的一套操作所有关系型数据库的规则(接口),各个数据库厂商去实现这套接口,提供数据库驱动jar包,我们使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类

2、MySql驱动包

官网地址 https://mvnrepository.com/artifact/mysql/mysql-connector-java

mysql-connector-java-5.1.49.jar 百度云:https://pan.baidu.com/s/17J2VfkGS2h44j69eB8TuFA提取码:nhnt

mysql-connector-java-8.0.25.jar 百度云:https://pan.baidu.com/s/1b8n7650uMKJtwidoptOjNQ提取码:wtvn

3、JDBC快速入门

3.1、建表和数据

USE test;
CREATE TABLE USER (id INT PRIMARY KEY AUTO_INCREMENT ,username VARCHAR(50),PASSWORD VARCHAR(50),birthday DATE
);
INSERT INTO USER (username, PASSWORD,birthday)
VALUES('admin1', '123','2000-12-24'),
('admin2','123','2003-12-24'),
('test1', '123','2006-12-24'),
('test2', '123','2005-12-24');

3.2、JDBC

5.x

public class Test {public static void main(String[] args) {Connection connection = null;Statement statement = null;ResultSet resultSet = null;try {// 1、注册驱动Class.forName("com.mysql.jdbc.Driver");// 2、获取连接String url="jdbc:mysql://localhost:3306/test";String username="root";String password="blingbling123.";connection = DriverManager.getConnection(url, username, password);//3、定义sqlString sql="select * from user";//4、获取指定sql对象statement = connection.createStatement();//5、执行sqlresultSet = statement.executeQuery(sql);//6、取出结果while (resultSet.next()){System.out.println(resultSet.getString("username"));}} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException throwables) {throwables.printStackTrace();} finally {//7、关闭连接if (resultSet!=null){try {resultSet.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (statement!=null){try {statement.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (connection!=null){try {connection.close();} catch (SQLException throwables) {throwables.printStackTrace();}}}}
}

8.x

public class Test {public static void main(String[] args) {Connection connection = null;Statement statement = null;ResultSet resultSet = null;try {// 1、注册驱动Class.forName("com.mysql.cj.jdbc.Driver");// 2、获取连接String url="jdbc:mysql://localhost:3306/test?serverTimezone=UTC&characterEncoding=utf-8&useSSL=false";String username="root";String password="blingbling123.";connection = DriverManager.getConnection(url, username, password);//3、定义sqlString sql="select * from user";//4、获取指定sql对象statement = connection.createStatement();//5、执行sqlresultSet = statement.executeQuery(sql);//6、取出结果while (resultSet.next()){System.out.println(resultSet.getString("username"));}} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException throwables) {throwables.printStackTrace();} finally {//7、关闭连接if (resultSet!=null){try {resultSet.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (statement!=null){try {statement.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (connection!=null){try {connection.close();} catch (SQLException throwables) {throwables.printStackTrace();}}}}
}

4、JDBC对象详解

4.1、Class.forName(“com.mysql.jdbc.Driver”);

查看源码发现:在com.mysql.cj.jdbc.Driver类中存在静态代码块

static {try {java.sql.DriverManager.registerDriver(new Driver());} catch (SQLException E) {throw new RuntimeException("Can't register driver!");}
}

mysql5之后的驱动jar包可以省略注册驱动的步骤

5.x

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

8.x

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

4.2、DriverManager(数据库连接对象)

方法声明功能介绍
Connection getConnection(String url, String user, String password)通过连接字符串和用户名,密码来获取数据库连接对象

5.x url

String url="jdbc:mysql://localhost:3306/test";

8.x url

String url="jdbc:mysql://localhost:3306/test?serverTimezone=UTC&characterEncoding=utf-8&useSSL=false";

4.3、Connection(数据库连接对象)

方法声明功能介绍
Statement createStatement()创建 SQL语句执行对象
PreparedStatement prepareStatement(String sql)创建 SQL语句执行对象(防注入)

4.4、Statement(执行sql对象)

方法声明功能介绍
boolean execute(String sql)可以执行任意的sql语句
int executeUpdate(String sql)执行DML(insert、update、delete)DDL(create,alter、drop)返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功
ResultSet executeQuery(String sql)执行DQL(select)语句

4.5、ResultSet(结果集对象)

方法声明功能介绍
boolean next()游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true
Xxx getXxx(参数):获取数据,Xxx:代表数据类型(int:列的编号,String:列名称)

5、抽取JDBC工具类

url=jdbc:mysql://localhost:3306/test
user=root
password=blingbling123.
driver=com.mysql.jdbc.Driver
public class JDBCtool {private static String urls;private static String user;private static String password;private static String driver;static {Properties properties=new Properties();ClassLoader classLoader=JDBCtool.class.getClassLoader();URL url=classLoader.getResource("connection.properties");String path=url.getPath();try {properties.load(new FileReader(path));} catch (IOException e) {e.printStackTrace();}urls=properties.getProperty("url");user=properties.getProperty("user");password=properties.getProperty("password");driver=properties.getProperty("driver");try {Class.forName(driver);} catch (ClassNotFoundException e) {e.printStackTrace();}}public static Connection getconnection() throws SQLException {return DriverManager.getConnection(urls,user,password);}public static void close(Connection connection, PreparedStatement preparedStatement, ResultSet resultSet){if (resultSet!=null){try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}}if (preparedStatement!=null){try {preparedStatement.close();} catch (SQLException e) {e.printStackTrace();}}if (connection!=null){try {connection.close();} catch (SQLException e) {e.printStackTrace();}}}
}
public class Test {public static void main(String[] args) throws SQLException {Connection connection = JDBCtool.getconnection();String sql="select * from user";PreparedStatement preparedStatement = connection.prepareStatement(sql);ResultSet resultSet = preparedStatement.executeQuery(sql);while (resultSet.next()){System.out.println(resultSet.getString("username"));}JDBCtool.close(connection,preparedStatement,resultSet);}
}

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

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

相关文章

android socket 框架c#,C#与Android Socket通信

【实例简介】C#做服务器,Android做客户端,实现Socket通信【实例截图】【核心代码】C与Android-Socket通信-yu└── C#与Android-Socket通信├── MySocketServer│ ├── MySocketServer│ │ ├── bin│ │ │ └── Debug│ │ …

Java JDBC篇2——JDBC增删查改

Java JDBC篇2——JDBC增删查改 urljdbc:mysql://localhost:3306/test userroot passwordblingbling123. drivercom.mysql.jdbc.Driverpublic class JDBCtool {private static String urls;private static String user;private static String password;private static String d…

android商品数量加减,微信小程序实现一个简单的商品数量加减案例

简介这是一个用微信小程序原生代码实现的数量加减demo,主要是用于商品购物车或者商品详情修改数量使用,很简单哦~~~。核心js方法说明addCount(增加数量)delCount (减少数量)getCount(获取数量)实现效果如下图所示:微信小程序实现一个简单的商…

Java JDBC篇3——JDBC事务

Java JDBC篇3——JDBC事务 1、事务方法 方法声明功能介绍void setAutoCommit(boolean autoCommit)参数是 true 或 false 如果设置为 false,表示关闭自动提交,相当于开启事务void commit()提交事务void rollback()回滚事务 2、步骤 获取连接开启事务获…

signature=1610c03482e0c6557f7ec99f0ceeae85,Vpdes Permit No. Va006557

摘要:PARK 500 4100. BERMUDA HUNDRED ROAD, CHESTER, VIRGINIA 23831 TELEPHONE (804) 751-2000 March 3, 1992 Mr. A. C. Ray Virginia Water Control Board Piedmont Regional Office P. 0. Box 11143 Richmond, Virginia 23230 Subject: VPDES Permit No. VA00…

Java JDBC篇4——数据库连接池

Java JDBC篇4——数据库连接池 1、DBCP 1.1、依赖jar包 官网:https://mvnrepository.com/artifact/org.apache.commons/commons-dbcp2 mysql-connector-java-5.1.49.jar 百度云:https://pan.baidu.com/s/17J2VfkGS2h44j69eB8TuFA提取码:n…

android plugin 镜像,cordova-plugin-screen-orientation

标题说明屏幕方向设置屏幕方向AppVeyor Travis CI Cordova屏幕方向插件Cordova插件以通用方式为 iOS。安卓和 windows UWP设置/锁定屏幕方向。 这个插件基于屏幕定向 API,所以API是当前的规范。插件将以下内容添加到屏幕对象( window.screen ):// lock the device o…

JAVA WEB篇1——初识JAVAWEB

JAVA WEB篇1——初识JAVAWEB JavaWeb主要指使用Java语言进行动态Web资源开发技术的统称,是解决相关Web互联网领域的技术总和 1、Http协议 HTTP协议(HyperText Transfer Protocol,超文本传输协议)是由W3C(万维网联盟…

osgi框架 android,基于OSGi的Android应用模块动态加载框架设计与实现

摘要:伴随着移动互联网科技水平向4G的飞跃,移动终端的使用日趋常态化,移动智能设备的普及率越来越高,得到了大量使用者的追捧。与此同时,各手机操作系统下应用商店里正充斥着琳琅满目的移动应用产品,用户对移动应用软件的期望值在逐步攀升,人们对移动应用软件的功能…

JAVA WEB篇2——Servlet

JAVA WEB篇2——Servlet Servlet(Server Applet)是Java Servlet的简称,称为小服务程序或服务连接器,是Java语言编写 的服务器端程序,换句话说,Servlet就是运行在服务器上的Java类。 Servlet用来完成B/S架构…

前台为html后台是asp在vs2012中建立什么,Asp.net中后台*.cs与前台JS脚本之间相互调用的几点心得...

Asp.net中后台*.cs与前台JS脚本之间相互调用的几点心得< type"text/javascript"> < type"text/javascript">一、 经 常需要在asp.net中“后台代码*.cs文件中调用javascript脚本中已经定义好的脚本函数”。基本包括一下几种办法&#xff1a;1. …

JAVA WEB篇3——JSP

JAVA WEB篇3——JSP 1、JSP是什么 JSP是Java Server Pages的简称&#xff0c;跟Servlet一样可以动态生成HTML响应&#xff0c; JSP文件命名为 xxx.jsp 与Servlet不同&#xff0c;JSP文件以HTML标记为主&#xff0c;然后内嵌Java代码段&#xff0c;用于处理动态内容 <% p…

JAVA WEB篇4——Filter、Listener

JAVA WEB篇4——Filter、Listener 1、Filter Filter本意为”过滤“的含义&#xff0c;是JavaWeb的三大组件之一&#xff0c;三大组件为&#xff1a;Servlet、Filter、 Listener过滤器是向 Web 应用程序的请求和响应处理添加功能的 Web 服务组件过滤器相当于浏览器与Web资源之…

html如何设置滚动条居中,css3内容垂直居中及垂直滚动条例子

垂直居中用得不少了&#xff0c;我在学习css3中也就碰到过了&#xff0c;在此小编就来为各位介绍css3内容垂直居中及垂直滚动条例子&#xff0c;希望文章对各位有帮助。内容垂直集中相对于内容在水平位置&#xff0c;内容在垂直方向是不好把控的&#xff0c;尤其当考虑到滚动条…

Java SSM1——Maven

Java SSM1——Maven 1、下载 maven 官网&#xff1a;https://maven.apache.org/download.cgi maven 百度云&#xff1a;https://pan.baidu.com/s/18XKbJp7P5x_BkKyc0VF0tw提取码&#xff1a;4zr9 2、安装 解压到想安装的目录下 添加环境变量 添加MAVEN_HOME变量 MAVEN_HO…

2021年广西艺术高考成绩查询,2021年广西美术高考成绩查询网址:https://www.gxeea.cn/...

【导语】2021年广西美术高考成绩查询入口开通后&#xff0c;考生可登录广西教育考试院(https://www.gxeea.cn/)高考服务平台或点击下方链接进入广西美术考成绩查询系统。具体如下&#xff1a;2021年广西美术高考成绩查询入口开通后&#xff0c;考生可以通过黑龙江教育考试院(ht…

齐浩亮 计算机科学与技术,齐浩亮

齐浩亮&#xff0c;男&#xff0c;1972年2月出生&#xff0c;计算机科学与技术系副教授&#xff0c;工学博士。2007年5月获哈尔滨工业大学计算机应用技术专业博士学位。现任黑龙江工程学院计算机应用技术研究所所长&#xff0c;哈尔滨院士专家团成员&#xff0c;YOCSEF哈尔滨20…

Java SSM篇2——框架的基本认识

Java SSM篇2——框架的基本认识 1、什么是框架 框架就是一套规范&#xff0c;既然是规范&#xff0c;你使用这个框架就要遵守这个框架所规定的约束框架可以理解为半成品软件&#xff0c;框架做好以后&#xff0c;接下来在它基础上进行开发 2、为什么使用框架 框架为我们封装…

计算机专业合成词,大学计算机论文范文大全.docx

大学计算机论文范文大全浅谈大学计算机专业英语双语教学摘要&#xff1a;本文针对计算机专业双语教学中存在的学生抵触、教师理解不足和教法单一等问题提出了改进的方案。关键词&#xff1a;计算机;英语双语教学;教育2001年&#xff0c;教育部对双语教学提出了具体明确的要求。…

Java SSM篇3——Mybatis

Java SSM篇3——Mybatis 1、JDBC存在的问题 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能sql 语句在代码中硬编码&#xff0c;造成代码不易维护&#xff0c;实际应用 sql 变化的可能较大&#xff0c;sql 变动需要改变java 代码查询操作时&#xff0c;需要手动将…