JDBC连接数据库,数据库访问层
为什么需要JDBC?
JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力。
JDBC API
提供者:Sun公司
内容:供程序员调用的接口与类,继承在java.sql和javax.sql包中,如:
DriverManager类
Connection接口
Statement接口
ResultSet接口
DriverManager
提供者:Sun公司
作用:管理各种不同的JDBC驱动
JDBC驱动:
提供者:数据库厂商
作用:负责连接各种不同的数据库
JDBC的功能**
JDBC API可做三件事:与数据库建立连接、执行SQL语句、处理结果.
JDBC步骤
1:加载驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
2:建立连接
connnection=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:jredu");
3:执行sql语句
ps=connnection.prepareStatement("select * from users where uname=? and pwd=?");
//向SQL语句添加数据 ?站位符,第一个下标为1,第二个下标为2
    ps.setString(1, user.getUname());
    ps.setString(2, user.getPwd());
4:获取到结果集
rs=ps.executeQuery();
5:把结果集转化成实体类
    user.setUname(rs.getString("uname"));
    user.setPwd(rs.getString("pwd"));
    user.setId(rs.getInt("id"));
    user.setSex(rs.getString("sex"));
    user.setEmail(rs.getString("email"));
    return user;
数据访问层(DAO)
DAO,
即Data Access Object(数据存取对象)。
位于业务逻辑和持久化数据之间。
实现对持久化数据的访问。
DAO模式的组成
DAO模式的实际应用
JDBC连接数据库,数据库访问层的更多相关文章
- Java 数据库访问层
		
最近项目中需要对mysql进行操作,数据库的知识早在本科毕业那会就忘光了,这几年开发都没接触到数据库的操作. 借这个机会重新学习,数据库访问层是对数据库操作的一个封装,屏蔽底层的数据操作细节,通过使用 ...
 - XAF使用数据库访问层缓存的提升性能
		
很多时候,为了提升性能,我们可以给数据库访问层做缓存. 以下几步可以完成这个任务:1. 使用自定义的 XPObjectSpaceProvider1.1. 创建自定义的 XPObjectSpacePro ...
 - MVC+Ef项目(3) 抽象数据库访问层的统一入口;EF上下文线程内唯一
		
抽象一个数据库访问层的统一入口(类似于EF的上下文,拿到上下文,就可以拿到所有的表).实际这个入口就是一个类,类里面有所有的仓储对应的属性.这样,只要拿到这个类的实例,就可以点出所有的仓储,我们在 R ...
 - MVC+Ef项目(2) 如何更改项目的生成顺序;数据库访问层Repository仓储层的实现
		
我们现在先来看看数据库的生成顺序 居然是 Idal层排在第一,而 web层在第二,model层反而在第三 了 我们需要把 coomon 公用层放在第一,Model层放在第二,接下来是 Idal ...
 - ASP.NET MVC+EF框架+EasyUI实现权限管理系列(2)-数据库访问层的设计Demo
		
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(2)-数据库访问层的设计Demo ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1)框架搭建 前言:这 ...
 - 使用Repository模式构建数据库访问层
		
使用Repository模式构建数据库访问层 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程[二]——使用Repository模式构建数据库访问层 系列导航地址http:// ...
 - GG_DataAccess 数据库访问层使用dapper操作
		
3.5.GG_DataAccess 数据库访问层使用dapper操作 和Model实体类同理,tt模板已写好,需要的可加qq群:547765059 自己下载.
 - (Entity framework 应用篇)把权限判断封装在数据库访问层
		
这里,我只是以一个例子,说一下简单权限控制,通过这个例子,大家可以设计庞大的权限管理层,把权限控制封装到数据库访问层,这样程序员就不用再写权限判断的代码了 首先,先看看我数据库DBContext的定义 ...
 - 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程【二】——使用Repository模式构建数据库访问层
		
系列导航地址http://www.cnblogs.com/fzrain/p/3490137.html 前言 在数据访问层应用Repository模式来隔离对领域对象的细节操作是很有意义的.它位于映射层 ...
 
随机推荐
- Maven仓库是什么
			
Maven仓库是基于简单文件系统存储的,集中化管理Java API资源(构件)的一个服务.仓库中的任何一个构件都有其唯一的坐标,根据这个坐标可以定义其在仓库中的唯一存储路径.得益于 Maven 的坐标 ...
 - Pytest测试框架(二):pytest 的setup/teardown方法
			
PyTest支持xUnit style 结构, setup() 和 teardown() 方法用于初始化和清理测试环境,可以保证测试用例的独立性.pytest的setup/teardown方法包括:模 ...
 - JAVA注解基础知识
			
定义-摘自JAVA编程思想 注解(元数据)为我们在代码中添加信息提供了一种形式化的方法,使我们在稍后某个时刻能非常方便的使用这些数据. 背景: 注解是JAVA5的一种新特性,是为应对C#等之类对JAV ...
 - 图解SparkStreaming与Kafka的整合,这些细节大家要注意!
			
前言 老刘是一名即将找工作的研二学生,写博客一方面是复习总结大数据开发的知识点,一方面是希望帮助更多自学的小伙伴.由于老刘是自学大数据开发,肯定会存在一些不足,还希望大家能够批评指正,让我们一起进步! ...
 - 探讨EFCore如何优雅的实现读写分离
			
前言 我们都知道当单库系统遇到性能瓶颈时,读写分离是首要优化手段之一.因为绝大多数系统读的比例远高于写的比例,并且大量耗时的读操作容易引起锁表导致无发写入数据,这时读写分离就更加重要了. ...
 - MP(MyBatis-Plus)实现乐观锁更新功能
			
实现步骤 step1:添加乐观锁拦截器 MP的其他拦截器功能可以参考官网 @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { ...
 - #3使用html+css+js制作网页 番外篇 使用python flask 框架 (I)
			
#3使用html+css+js制作网页 番外篇 使用python flask 框架(I 第一部) 0. 本系列教程 1. 准备 a.python b. flask c. flask 环境安装 d. f ...
 - 【对线面试官】Java 反射&&动态代理
			
// 抽象类,定义泛型<T> public abstract class BaseDao<T> { public BaseDao(){ Class clazz = this.g ...
 - 【剑指 Offer】10-I.斐波那契数列
			
题目描述 写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项.斐波那契数列的定义如下: F(0) = 0, F(1) = 1 F(N) = F(N - 1) + F(N - ...
 - 关于spring-data与elasticsearch的使用,自定义repository
			
之前没有使用过spring-data,关于spring-data有很多很棒的设计,例如仅仅只需要声明一个接口就行,你甚至都不需要去实现,spring-data有内置默认的实现类,基本就上完成绝大多数对 ...