java spring jdbc_Spring与JDBC支持

JDBC是一种标准Java编程接口(JAVA API),可以将Java编程语言与广泛数据库进行连接。

JDBC API库包含下面提到的每个任务,都是与数据库相关的常用用法。数据库的连接

创建sql语句

执行或提交sql语句

查看或修改查询到的记录

从根本上说,JDBC是一种规范,它提供了一套完整的接口,可以便携式访问底层数据库。

JDBC架构

JDBC API支持两层或三层的处理模式连接数据库,但一般只使用两层处理模式。JDBC API:提供了应用程序对JDBC管理器的连接。

JDBC DRIVER API:提供了JDBC管理器对驱动程序的连接。

JDBC API使用驱动程序管理器和数据库特定的驱动程序来提供异构(heterogeneous)数据库的透明连接。

JDBC驱动程序管理器可确保正确的驱动程序访问每个数据源,驱动程序管理器能够支持连接多个异构数据库的多个并发驱动程序。

JDBC API 提供了以下接口和类

DriverManager:这个类管理一系列数据库驱动程序。使用通信子协议从Java应用程序中请求合适的数据库驱动程序,建立数据库连接。

Driver:这个接口处理与数据库服务器的通信。我们将很少直接与驱动陈旭互动。

Connection:此接口具有操作数据库的所有方法。改连接对象表示通信上下文,即所有与数据库的通信仅通过这个对象连接。

Statement:这个接口的对象将sql语句提交到数据库。

ResultSet:这个接口保存sql语句查询结果。

SqlException:这个类处理发生在数据库应用程序的任何错误。

代码示例

Customer类

public class Customer {

int custId;

String name;

int age;

//getter and setter methods}

数据库访问DAO

public interface CustomerDAO{

public void insert(Customer customer);

public Customer findByCustomerId(int custId);

}

/*** @author :fengzhiwei* @date :Created in 2019/6/10 11:16* @description:${description}*/

public class JdbcCustomerDAO implements CustomerDAO {

private DataSource dataSource;

public DataSource getDataSource() {

return dataSource;

}

public void setDataSource(DataSource dataSource) {

this.dataSource = dataSource;

}

@Override

public void insert(Customer customer) {

StringBuilder sb = new StringBuilder();

sb.append("insert into customer ")

.append("(cust_id, name, age) ")

.append("value ")

.append("(?,?,?)");

Connection connection = null;

try {

connection = dataSource.getConnection();

PreparedStatement preparedStatement = connection.prepareStatement(sb.toString());

preparedStatement.setInt(1, customer.getCustId());

preparedStatement.setString(2, customer.getName());

preparedStatement.setInt(3, customer.getAge());

preparedStatement.executeUpdate();

preparedStatement.close();

} catch (SQLException e) {

throw new RuntimeException(e);

} finally {

if (connection != null) {

try {

connection.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

}

@Override

public Customer findByCustomerId(int custId) {

StringBuilder sb = new StringBuilder("select * from cutomer where cust_id = ?");

Connection connection = null;

Customer customer = null;

try {

connection = dataSource.getConnection();

PreparedStatement preparedStatement = connection.prepareStatement(sb.toString());

preparedStatement.setInt(1, custId);

ResultSet resultSet = preparedStatement.executeQuery();

if (resultSet.next()) {

customer = new Customer();

customer.setCustId(resultSet.getInt("cust_id"));

customer.setAge(resultSet.getInt("age"));

customer.setName(resultSet.getString("name"));

}

resultSet.close();

preparedStatement.close();

} catch (SQLException e) {

throw new RuntimeException(e);

} finally {

if (connection != null) {

try {

connection.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

return customer;

}

}

Spring 配置文件

class="org.springframework.jdbc.datasource.DriverManagerDataSource">

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

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

相关文章

局域网内连接MySQL

2019独角兽企业重金招聘Python工程师标准>>> 局域网内连接MySQL 博客分类: MySQL MySQL局域网连接grant 我们都知道连接MySQL一般用的语句就是 jdbc:mysql://localhost:3306/database, 但是当你要连接到其他机器上的mysql的时候,…

java打印的globa类l_Spring异常集中处理和日志集中打印

使用ControllerAdvice和ExceptionHandler处理Controller层的异常:ControllerAdvicepublic class GlobalExceptionHandler {private static final Logger LOGGER LoggerFactory.getLogger(GlobalExceptionHandler.class);/*** 处理所有不可知的异常* param e* retur…

[leetcod] Clone Graph

题目: Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. OJs undirected graph serialization: Nodes are labeled uniquely. We use # as a separator for each node, and , as a separator for node label and …

【iOS7一些总结】9、与列表显示(在):列表显示UITableView

列表显示,顾名思义它是在一个列表视图的形式显示在屏幕上的数据的内容。于ios在列表视图UITableView达到。这个类在实际应用中频繁,是很easy理解。这里将UITableView的主要使用方法总结一下以备查。UITableView定义在头文件UITableView.h中,详…

java聊天软件课程设计_[计算机课程设计] JAVA课程设计-聊天室

本系统基于C/S模式。新的时代,新的世纪,在当今这个发达的信息时代,网上办公,极为普遍,生活变的简单化,人们在家就可以办公,是信息化时代的标志.我经过多方的调查和研究,并灵活运用了自己所学的知识,编写了这个非常适用的一个小软件.它是通过RMI通信协议,利用JAVA的多线程技术,将…

iOS 获取手机信息

待续;转载于:https://www.cnblogs.com/xieyier/p/4194271.html

show status和show variables区别解析

1.show status 查看系统运行的实时状态,便于dba查看mysql当前运行的状态,做出相应优化,动态的,不可认为修改,只能系统自动update。MariaDB [(none)]> show status like %conn%;--------------------------------…

【Javascript 拾遗之三】Closure 闭包

说起闭包这个概念,其实是离散数学中的一种定义,而很程序员们耳熟能详但不一定能说清楚它的含义和用途。本文先简单地介绍下离散数学中的闭包,然后再探讨一下Javascript语言中的闭包是如何创建和应用的。 Closure 闭包 1、闭包的定义 -离散数学…

java递归空瓶换饮料_问题描述:一次买n瓶可乐,k个空瓶可以换一瓶饮料,那么一共能喝多少瓶饮料? | 学步园...

/***问题描述:一次买n瓶可乐,k个空瓶可以换一瓶饮料,那么一共能喝多少瓶饮料?*下面用不同的方法实现了这个问题(Java实现):*1.递归方法*2.非递归方法*3.公式法*/public class CocaCola{public int Count(int n, int k)…

SpringMVC(一):环境搭建

2019独角兽企业重金招聘Python工程师标准>>> //TODO 转载于:https://my.oschina.net/u/1020238/blog/505272

DockPanel 类

DockPanel 类 .NET Framework 4.5其他版本此主题尚未评级 - 评价此主题定义您可水平或垂直排列子元素的区域,互相。 继承层次结构 System.Object System.Windows.Threading.DispatcherObjectSystem.Windows.DependencyObjectSystem.Windows.Media.VisualSystem.Wind…

java动态json入库_从JSon File动态生成模式

一些兴趣点:1)您不需要数据帧来加载您的json架构 . 模式在驱动程序上加载和执行,因为不需要分发那些不必要的开销2)我构造了一个JColumn对象的List,并将它传递给StructType以动态构造模式3)inferSchema应该是false,因为我们明确定…

【分布式计算】MapReduce的替代者-Parameter Server

原文:http://blog.csdn.net/buptgshengod/article/details/46819051 首先还是要声明一下,这个文章是我在入职阿里云1个月以来,对于分布式计算的一点肤浅的认识,可能有些地方不够妥善,还请看官可以指出不足的地方&#…

java迭代器逆序_迭代器

提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。迭代器模式(Iterator)实际上在Java的集合类中已经广泛使用了。我们以List为例,要遍历ArrayList,即使我们知道它的内部存储了一个Object[]数组,也不…

iOS开发多线程篇—线程安全

iOS开发多线程篇—线程安全 一、多线程的安全隐患 资源共享 1块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源 比如多个线程访问同一个对象、同一个变量、同一个文件 当多个线程访问同一块资源时,很容易引发数据错乱和数据安全问题 示例…

java程序可分为两个基本文件_1 Java语言概述答案

第1章 Java语言概述一、判断题1.Java语言是一种解释执行的语言,这个特点是Java语言的一个缺点。(F)2.Java源程序的文件名一定要与文件中某个类的名称一致。(T)3.Java语言采用面向对象的思想编程,具有跨平台、分布式、多…

JQuery中的siblings()是什么意思

siblings()函数用于选取每个匹配元素的所有同辈元素(不包括自己),并以jQuery对象的形式返回。转载于:https://www.cnblogs.com/DTWolf/p/4807277.html

sql server 日期类型

下面是结果集: 数据类型 输出 time 12:35:29. 1234567 date 2007-05-08 smalldatetime 2007-05-08 12:35:00 datetime 2007-05-08 12:35:29.123 datetime2 2007-05-08 12:35:29. 1234567 datetimeoffset 2007-05-08 12:35:29.1234567 12:15 转载于:htt…

以太坊java接口_java以太坊库web3j文档

通过java打包以太坊智能合约Web3j可以自动打包智能合同代码,以便在不脱离JVM的情况下进行以太坊智能合同部署和交互。要打包代码,需要先编译智能合同:$ solc .sol --bin --abi --optimize -o /web3j solidity generate /path/to/.bin /path/t…

【Android车载系统 News | Tech 1】News 谷歌开发车载Android系统 2014-12-19

据外国媒体报道,Android和iOS两大操作系统在垄断手机和平板之后,开始向智能家居、智能汽车、客厅娱乐、物联网等领域扩张。谷歌和苹果此 前均推出了连接智能手机和车载信息系统的平台产品。2014年12月18日,谷歌正计划开发一种汽车信息系统使用…