JSP:JDBC

JDBCJava Data Base Connectivity的缩写)是Java程序操作数据库的API,也是Java程序与数据库相交互的一门技术。

JDBCJava操作数据库的规范,由一组用Java语言编写的接口组成,它对数据库的操作提供基本方法,但对于数据库的细节操作由数据库厂商进行实现,使用JDBC操作数据库,需要数据库厂商提供数据库的驱动程序。

关于Java程序与数据库相交互的示意图如下图所示。

JDBC(Java Database Connectivity) Java数据库连接,是一组用来按照统一方式访问数据库的API。它向程序员提供了独立于数据库的统一接口,可以使开发人员不必考虑所用的特定数据库便可编写应用程序,实现了Java与数据库的互连。

由一组用Java语言编写的类和接口组成它能够:与数据库建立连接、发送SQL语句、处理结果JDBC的主要接口

java.sql.Driver:任何驱动程序类都应该实现这个接口。读取数据库驱动器的信息、提供connect方法用于建立访问数据库所用的Connection对象

java.sql.DriverManager:用于管理JDBC驱动程序一个接口(使用此接口能够获得与相应数据库的连接)

java.sql.Connection:表示驱动程序与数据库之间的连接。(使用此连接可以创建一个Statement对象)

java.sql.Statement:能对数据库执行SQL语句,并得到返回的结果

java.sql.ResultSet:表示从数据库服务器返回的结果集。

ResultSet 有如下几个方法

1. boolean  next()

用于将 ResultSet定位到下一行

ResultSet最初是定位在第0行上的,此时应该先调用  next()方法将其定位到第1行上,然后才可输出。当 ResultSet已经到了最后一行时,再调用next()方法,则返回 false。

2. getXXX()

ResultSet已经定位在某一行上时,使用 getXxx ()方法得到这一行上单个字段的值。针对不同的字段类型,调用不同的getXxx ()方法(getString(col), getDate(col), getInt(col),…)

例:如果表中的第一个字段,字段名为“name”是文本型的; 则可以使用getString

(1)getString(“name”)来得到它的值。

如果表中的第三个字段,字段名为“score”是数值型的; 则可以使用getFloat(3) getFloat(“score”)来得到它的值。显示结果集中所有记录的前两列:

while(rs.next())

{

name =rs.getString(1);

phone =rs.getString(2);

System.out.println(name+","+phone);

}

JDBC连接数据库的过程

在了解了JDBC与数据库后,下面向大家介绍使用JDBC操作数据的开发流程,其关键步骤如下:(1)注册数据库驱动 :加载数据库驱动,注册到驱动管理器Class.forName(“com.mysql.jdbc.Driver”);

(2构建数据库连接URL     “JDBC协议+IP地址或域名+端口+数据库名称

MySQL连接URL的字符串为:“jdbc:mysql://localhost:3306/test”

3获取Connection对象

注册了数据库驱动及构建数据库URL后,通过驱动管理器获取数据库的连接ConnectionConnection对象是JDBC封装的数据库连接对象,创建此对象后,才可以对数据库进行相关操作:DriverManager.getConnection(url, username, password);

使用JDBC驱动程序访问数据库

获取相应数据库的jdbc驱动程序,并将它们保存在指定的位置, 然后重新启动tomcat服务

连接的具体步骤:以打电话通知同学为你带书为例…编写程序的具体步骤编写程序

加载驱动程序;---打开手机、找到电话簿:亲人、同学、朋友

定义所要连接数据库的地址;---定位到同学

建立与数据库的连接;--拨号给他打电话

建立语句对象;--接通后,你(对象)可以跟他(数据库)交流了

声明并执行SQL语句--任务:帮你带书

处理返回的结果--给带或是不能带

关闭对象--挂电话

首先应该导入java.sql。语句为: <%@ page import="java.sql.*" %>

利用Class.forName()方法加载某一个数据库的驱动程序。

语法:Class.forName(“JDBC驱动程序类);

方法:例1:使用JDBC/ODBC桥驱动程序:Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);

例2:使用SQLServer的驱动程序:Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”);

经过以上其中之一语句的声明后,驱动程序就会自动地加载。

注意:如果classpath路径中没有找到所需的驱动程序则会抛出 ClassNotFoundException异常。

通过此步骤,定义要连接的数据库资源

String ODBCURL" jdbc:odbc:dbName";

String sqlserverURL" jdbc:microsoft:sqlserver://host:1433;DatabaseName=dbName ";

String mysqlURL= "jdbc:mysql://host:port/dbName ";

String oracleURL= "jdbc:oracle:thin:@host:port:dbName ";

不同数据库连接的地址不同,这点需要特别注意

URL3部分组成,各个部分用冒号间隔,格式如下jdbc:<子协议>:<子名称>      

JDBC URL的3部分可分解如下:jdbc:JDBC中的协议就是jdbc

<子协议>数据库驱动程序名或数据库连接机制的名称。子协议的典型示例为oracle它用于连接oracle数据库

<子名称>一种标记数据库的方法。子名称根据子协议的不同而不同,使用子名称的目的是为定位数据库

例如 jdbc:oracle:thin:@[ip]:[port]:[sid]

子协议现在是 oracle子名称现在由四部分构成:包括驱动程序类型thin数据库服务器的IP地址提供服务的端口号、数据库的名字

语法:Connection con=DriverManager.getConnection(url,”登录数据库用户名,”登录密码);

例:以SQLServer连接数据库book为例用户名为sa,密码为123

Class.forName(" com.microsoft.jdbc.sqlserver.SQLServerDriver ");

String connStr=" jdbc:microsoft:sqlserver://host:1433;DatabaseName=book";

Connection conn = DriverManager.getConnection(connStr, " sa", " 123");

利用 Connection接口à createStatement() 方法创建语句对象

例:Statement stmt=conn.createStatement();

语句对象用于执行SQL语句。该对象负责将SQL语句传递给数据库管理系统执行;声明SQL语句,并将该语句通过Statement对象提交给服务器进行执行

String sql= " SELECT * FROM book ";//上面的语句用于从book表中查询所有记录

ResultSet resultSet=stmt.executeQuery(sql);//该语句将sql命令提交给数据库服务器进行执行,并将执行结果存储在ResultSet对象中进行执行。

Statement接口主要有如下三个方法:

 1. ResultSet  executeQuery(String sql)以sql语句为参数执行sql查询语句

      返回ResultSet结果集(一个二维表)

例如:

Statement stmt=con.createStatement();

Stringsql= " SELECT * FROM book ";

ResultSet rs=stmt.executeQuery(sql);

2. int  executeUpdate(String sql)

以sql语句为参数,执行sql更新语句及DDL语句,如添加、删除或修改操作,返回被受影响记录的条数。例如:

Statement stmt=con.createStatement();

String sql= " delete FROM book where bookid= " + " ‘12335’ ";

int i=stmt.executeUpdate(sql);

System.out.println(i);

3. boolean execute(String sql)

用于执行实现不知道类型的SQL语句,既可以执行查询语句,也可以执行更新语句

常用于动态的处理未知的SQL语句,事先无法知道该SQL语句的具体类型及执行的返回值

执行参数部分的SQL语句

当SQL语句的执行结果是一个ResultSet结果集时,本方法返回true并可以通过StatementàgetResultSet()方法得到返回的结果集

SQL语句执行后没有返回的结果集时,该方法返回false

Statement对象负责将SQL语句传递给数据库管理系统执行,返回的是一个ResultSet的对象 ResultSet对象,称为结果集是符合条件的所有行的集合

可以通过(first(), last(), previous(), next(), absolute(int), …) 方法浏览可滚动结果集中的内容rs.close();//关闭结果集

stmt.close();//关闭语句对象

con.close();//关闭连接

将打开的资源关闭。注意:资源关闭的顺序和打开的顺序恰恰相反。

异常处理   数据库访问中可能会发生异常(如无法连接),需要做异常处理

编写Servlet时,需要将访问数据库代码放在try-catch结构中

try { …}catch(SQLExceptionex){ …}

在编写JSP页面时,数据库操作可以不写try-catch, 服务器将JSP编译成Servlet时会自动加上try-catch

7.2 通过JDBC连接MySQL数据库

(1)创建名称为10.1的动态Web项目,将MySQL数据库的驱动包添加至项目的构建路径,构建开发环境

(2) 创建程序中的主页index.jsp,在该页面中加载数据库驱动并创建数据库连接

应用程序为了能和数据库交互信息,必须首先和数据库建立连接。目前在开发中常用的连接数据库的方式是加载JDBC-数据库驱动程序。

Java语言编写的数据库驱动程序称作JDBC-数据库驱动程序。JDBC可以调用本地的JDBC-数据库驱动程序和相应的数据库建立连接,如图所示。

使用JDBC-数据库驱动程序方式和数据库建立连接需要经过2个步骤

加载JDBC-数据库驱动程序

② 和指定的数据库建立连接。

使用JDBC-数据库驱动程序访问数据库时,必须要保证连接数据库的应用程序所驻留的计算机上安装有相应JDBC-数据库驱动程序,比如,Tomcat服务器上的某个Web应用程序想访问MySQL数据库管理系统所管理的数据库,那么Tomcat服务器所驻留的计算机上必须要安装MySQL提供的JDBC-数据库驱动程序。

登录MySQL的官方网站www.mysql.com下载JDBC-数据库驱动程序(JDBC Driver for MySQL)。本教材下载的是mysql-connector-java-5.1.28.zip

解压后的mysql-connector-java-5.1.28-bin.jar复制到Tomcat服务器所使用的JDK的扩展目录中。应用程序加载MySQLJDBC-数据库驱动程序代码如下:

 try{

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

 }  catch(Exception e){

 }

Java.sql包中的DriverManager类有两个用于建立连接的类方法:

Connection getConnection(java.lang.String, java.lang.String, java.lang.String)

Connection getConnection(java.lang.String)

数据库服务器占用的端口是3306,假设MySQL数据库服务器所驻留的计算机的IP地址是192.168.100.1。应用程序要和warehouse建立连接,用户的id和密码分别是root99

 那么使用Connection getConnection(java.lang.String, java.lang.String, java.lang.String)

方法建立连接的代码如下:

try{  String uri = "jdbc:mysql:// 192.168.100.1:3306/warehouse"

String user ="root";

String password ="99";

con = DriverManager.getConnection(uri,user,password);

 }catch(SQLException e){

System.out.println(e);

}

使用Connection getConnection(java.lang.String) 方法建立连接的代码如下:

try{  String uri =" jdbc:mysql:// 192.168.100.1:3306/warehouse?user=root&password=99";

con = DriverManager.getConnection(uri);

}catch(SQLException e){

System.out.println(e);

}

在某些Web程序中需要避免操作数据库出现中文乱码,那么需要使用

Connection getConnection(java.lang.String) 方法建立连接,连接中的代码是(假设用户是root,其密码是99):

String uri = "jdbc:mysql://127.0.0.1/warehouse?"+"user=root&password=99&characterEncoding=gb2312";

con = DriverManager.getConnection(uri);

应用程序一旦和某个数据库建立连接,就可以通过SQL语句和该数据库中的表交互信息,比如查询、修改、更新表中的记录
 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

YaRN方法:无需微调,高效扩展语言模型上下文窗口/蚂蚁集团与浙大发布原生安全框架v1.0,引领企业网络安全新时代 |魔法半周报

我有魔法✨为你劈开信息大海❗ 高效获取AIGC的热门事件&#x1f525;&#xff0c;更新AIGC的最新动态&#xff0c;生成相应的魔法简报&#xff0c;节省阅读时间&#x1f47b; &#x1f525;资讯预览 YaRN方法&#xff1a;无需微调&#xff0c;高效扩展语言模型上下文窗口 蚂蚁…

【Python】itertools模块,补充:可迭代对象、迭代器

Python中 itertools模块创建高效迭代器、处理序列数据集。 此模块所有函数返回迭代器&#xff0c;可用for循环获取迭代器中的内容&#xff0c;也可用list(...)用列表形式显示内容。 import itertools[ x for x in dir(itertools) if not x.startswith(_)] # 结果&#xff1a;…

从零开始,用Docker-compose打造SkyWalking、Elasticsearch和Spring Cloud的完美融合

&#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 "从零开始&#xff0c;用Docker-compose打造SkyWalking、Elasticsearch和Spring Cloud的完美融合 前言准备工作编写docker-compose.yml文件为什么使用本机ip为什么skywa…

Java 简单配置环境变量,切换多个jdk版本

文章目录 前言一、jdk下载二、配置环境变量三、查看jdk版本四、配置多个jdk五、切换jdk 前言 windows 配置jdk环境变量&#xff0c;如果项目没有规定使用的jdk版本的话&#xff0c;建议使用jdk8&#xff0c;这是最常用也是最稳定的版本 一、jdk下载 https://www.oracle.com/ja…

技术部工作职能规划分析

前言 技术部的职能。以下是一个基本的框架,其中涵盖了技术部在公司中的关键职能和子职能。 主要职能 技术部门的主要职能分为以下几个板块: - 技术规划与战略: 制定技术规划和战略,与业务团队合作确定技术需求。 研究和预测技术趋势,引领公司在技术创新和数字化转型方…

PC分页操作以及loading效果

page-size 每页显示条目个数 current-page 当前页数 total 数据总数 current-change【currentPage 改变时会触发】 切换分页时会先加载&#xff0c;等在接口数据&#xff0c;接口返回&#xff0c;加载会关闭&#xff08;在获取接口数据完毕哪里加上this.loadingfalse&#xff0…

苹果引导式访问是什么意思?怎么使用?这里有答案!

可能还有很多小伙伴都不知道&#xff0c;苹果手机里有一个隐藏的功能叫做引导式访问。引导式访问是什么意思&#xff1f;引导式访问是一种特殊的功能&#xff0c;可以帮助用户限制在某个应用程序中的操作&#xff0c;以保护隐私或防止误操作。今天&#xff0c;小编将给大家详细…

【免费】小傅哥 DDD 开发小册

作者&#xff1a;小傅哥 博客&#xff1a;https://bugstack.cn 沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;&#x1f604; 大家好&#xff0c;我是技术UP主小傅哥。 如果在面试的时候&#xff0c;面试官问你DDD是什么&#xff0c;你怎么解释&#xff1…

某上市证券公司:管控文件交换行为 保护核心数据资产

客户简介 某上市证券公司成立于2001年&#xff0c;经营范围包括&#xff1a;证券经纪、证券投资咨询、证券承销与保荐、证券自营等。经过多年发展&#xff0c;在北京、上海、深圳、重庆、杭州、厦门等国内主要中心城市及甘肃省内各地市设立了15家分公司和80余家证券营业部。20…

F盘满了变成红色怎么清理?这4个简单方法记得收藏!

“因为我电脑的磁盘比较多&#xff0c;我通常会把一些比较重要的文件放在F盘中。但是很奇怪&#xff0c;我的F盘用着用着就满成红色了&#xff0c;这该怎么办呢&#xff1f;应该怎么进行清理呢&#xff1f;” 我们在使用电脑时都会发现&#xff0c;电脑上有很多的磁盘。我们可以…

python 爬百度热搜并生成词云

1、爬取百度body存入txt def get_baidu_hot():url "https://top.baidu.com/board?tabrealtime"headers {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3&…

Mysql 锁机制分析

整体业务代码精简逻辑如下&#xff1a; Transaction public void service(Integer id) {delete(id);insert(id); }数据库实例监控&#xff1a; 当时通过分析上游问题流量限流解决后&#xff0c;后续找时间又重新分析了下问题发生的根本原因&#xff0c;现将其总结如下&#xf…

Android : AlertDialog对话框、单选、多选、适配器-简单应用

示例图&#xff1a; 1 &#xff1a;创建 AlertDialog.Builder 对象&#xff1b; 2 &#xff1a;调用 setIcon() 设置图标&#xff0c; setTitle() 或 setCustomTitle() 设置标题&#xff1b; 3 &#xff1a;设置对话框的内容&#xff1a; setMessage() 还有其他方法来指定显示…

成为AI产品经理——模型构建流程(下)

目录 1.模型训练 2.模型验证 3.模型融合 4.模型部署 上节课我们讲了模型设计、特征工程&#xff0c;这节课我们来讲模型构建剩下的三个部分&#xff1a;模型训练、模型验证和模型融合。 1.模型训练 模型训练就是要不断地训练、验证、调优直至让模型达到最优。 那么怎么达…

沃趣班11月月考题目解析

沃趣班11月月考题目解析 1.在oracle中创建用户时&#xff0c;若未设置default tablespace关键字&#xff0c;则oracle将哪个表空间分配给用户作为默认表空间 答案&#xff1a;D.user SQL> create user mytest identified by 123456; SQL> grant connect to mytest; SQL…

【解决】HDFS JournalNode启动慢问题排查

文章目录 一. 问题描述二. 问题分析1. 排查机器性能2. DNS的问题 三. 问题解决 一句话&#xff1a;因为dns的问题导致journalnode启动时很慢&#xff0c;通过修复dns对0.0.0.0域名解析&#xff0c;修复此问题。 一. 问题描述 从journalnode启动到服务可用&#xff0c;完成RPC…

又一重量级RTOS及组件开源,免费商用,支持更宽松 MIT 协议

关注星标公众号&#xff0c;不错过精彩内容 作者 | strongerHuang 微信公众号 | strongerHuang 不知道大家有没有发现&#xff1a;面向大众的软件代码&#xff0c;开源才是“王道”&#xff1f; FreeRTOS之所以这么流行&#xff0c;很大程度在于它免费开源&#xff08;遵循MIT开…

22款奔驰S400L升级主动式氛围灯 光影彰显奔驰的完美

新款奔驰S级原车自带64色氛围灯&#xff0c;还可以升级原厂的主动式氛围灯&#xff0c;增加车内的氛围效果。主动式环境氛围灯包含263个LED光源&#xff0c;每隔1.6厘米就有一个LED光源&#xff0c;照明效果较过去明亮10倍&#xff0c;视觉效果更加绚丽&#xff0c;它还可结合智…

【C++】内存管理(new与delete)

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 前言 本篇文章我们一起来学习C的内存管理方式&…

「 高并发系统设计 」 如何提高系统性能

「 高并发系统设计 」 如何提高系统性能 参考&鸣谢 ⾼并发系统如何做性能优化&#xff1f; 玄明Hanko 高并发系统设计和优化的通用方法论 渝言家 文章目录 「 高并发系统设计 」 如何提高系统性能[toc]一、高并发系统设计三大目标高性能高可用可扩展 二、性能优化原则问题导…