前言

当我们学完数据库之后总觉得数据库和java之间是没有联系的,但是我们还是要去学数据库是为了什么呐?现在就来了,现在我就来给大家讲讲怎么将数据库和java进行联系,我们也可以用数据库代替以前的IO流来存东西了。

JDBC

概述

JDBC(Java Database Connectivity)是一个独立于特定数据库管理系统、通用的SQL数据库存取和操作的公共接口(一组API),定义了用来访问数据库的标准Java类库,(java.sql,javax.sql)使用这些类库可以以一种标准的方法、方便地访问数据库资源。

JDBC为访问不同的数据库提供了一种统一的途径,为开发者屏蔽了一些细节问题。

JDBC的目标是使Java程序员使用JDBC可以连接任何**提供了JDBC驱动程序**的数据库系统,这样就使得程序员无需对特定的数据库系统的特点有过多的了解,从而大大简化和加快了开发过程。

JDBC程序编写步骤

获取数据库连接

要素一:Driver接口实现类

我们在链接数据库之前我们需要一个Driver接口的实现类,但是我们的java中又没有自带这个包所以我们需要往我们的工程文件中添加一个MySQL的jar包才能使用相关的东西。

我们在idea中的操作是这样的:

先找到项目的添加的地方

再点如图的加号

然后点第一个

我们就可以从我们保存的目录中导入需要的包了

要素二:URL

JDBC URL 用于标识一个被注册的驱动程序,驱动程序管理器通过这个 URL 选择正确的驱动程序,从而建立到数据库的连接。  我以MySQL为例我们常用的就是入下的样子

要素三:用户名和密码

user,password可以用“属性名=属性值”方式告诉数据库

可以调用 DriverManager 类的 getConnection() 方法建立到数据库的连接

前面的三步就是我们需要获取连接必要的三部。

实现代码:

 //1.加载配置文件InputStream is = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");Properties pros = new Properties();pros.load(is);//2.读取配置信息String user = pros.getProperty("user");String password = pros.getProperty("password");String url = pros.getProperty("url");String driverClass = pros.getProperty("driverClass");//3.加载驱动Class.forName(driverClass);//4.获取连接Connection conn = DriverManager.getConnection(url,user,password);System.out.println(conn);

其中,配置文件声明在工程的src目录下:【jdbc.properties】

user=root
password=abc123
url=jdbc:mysql://localhost:3306/test
driverClass=com.mysql.jdbc.Driver

而我们使用配置文件的好处就是:

①实现了代码和数据的分离,如果需要修改配置信息,直接在配置文件中修改,不需要深入代码 ②如果修改了配置信息,省去重新编译的过程。

使用PreparedStatement实现查询操作

当我们获得了连接之后我们就需要进行操作了,首先我们需要一个同用的查询

// 通用的针对于不同表的查询:返回一个对象 (version 1.0)public <T> T getInstance(Class<T> clazz, String sql, Object... args) {Connection conn = null;PreparedStatement ps = null;ResultSet rs = null;try {// 1.获取数据库连接conn = JDBCUtils.getConnection();// 2.预编译sql语句,得到PreparedStatement对象ps = conn.prepareStatement(sql);// 3.填充占位符for (int i = 0; i < args.length; i++) {ps.setObject(i + 1, args[i]);}// 4.执行executeQuery(),得到结果集:ResultSetrs = ps.executeQuery();// 5.得到结果集的元数据:ResultSetMetaDataResultSetMetaData rsmd = rs.getMetaData();// 6.1通过ResultSetMetaData得到columnCount,columnLabel;通过ResultSet得到列值int columnCount = rsmd.getColumnCount();if (rs.next()) {T t = clazz.newInstance();for (int i = 0; i < columnCount; i++) {// 遍历每一个列// 获取列值Object columnVal = rs.getObject(i + 1);// 获取列的别名:列的别名,使用类的属性名充当String columnLabel = rsmd.getColumnLabel(i + 1);// 6.2使用反射,给对象的相应属性赋值Field field = clazz.getDeclaredField(columnLabel);field.setAccessible(true);field.set(t, columnVal);}return t;}} catch (Exception e) {e.printStackTrace();} finally {// 7.关闭资源JDBCUtils.closeResource(conn, ps, rs);}return null;}

获取连接的封装:

   public static Connection getConnection()throws Exception{InputStream is =Connectiontest.class.getClassLoader().getResourceAsStream("jdbc.properties");Properties pros=new Properties();pros.load(is);String user=pros.getProperty("user");String password=pros.getProperty("password");String url=pros.getProperty("url");String driverName=pros.getProperty("driverName");Class.forName(driverName);Connection conn=DriverManager.getConnection(url,user,password);return conn;}

关闭流的操作:

 public static void closeResource(Connection conn, Statement ps,ResultSet rs){try{if(ps!=null)ps.close();}catch (SQLException e){e.printStackTrace();}try{if(conn!=null)conn.close();}catch (SQLException e){e.printStackTrace();}try{if(rs !=null)rs.close();}catch (SQLException e){e.printStackTrace();}}

查询的样子:

 System.out.println("请输入需要查询的用户名称:");Scanner sc=new Scanner(System.in);String a=sc.next();String sql="select employee_id id,first_name name from employees where first_name=? ";employees instance = getInstance(employees.class, sql, a);System.out.println(instance);

而其中的那个employees是我们需要查询的表所对应的实体类,实体类里面的属性和表中的列名相对应。

使用PreparedStatement实现增、删、改操作

由于增删改的操作都差不多所以可以由一个通用的来实现:

//通用的增、删、改操作(体现一:增、删、改 ; 体现二:针对于不同的表)public void update(String sql,Object ... args){Connection conn = null;PreparedStatement ps = null;try {//1.获取数据库的连接conn = JDBCUtils.getConnection();//2.获取PreparedStatement的实例 (或:预编译sql语句)ps = conn.prepareStatement(sql);//3.填充占位符for(int i = 0;i < args.length;i++){ps.setObject(i + 1, args[i]);}//4.执行sql语句ps.execute();} catch (Exception e) {e.printStackTrace();}finally{//5.关闭资源JDBCUtils.closeResource(conn, ps);}}

获取流和上面的查找一样,只有关闭流会少一个如下:

 public static void closeResource(Connection conn, Statement ps){try{if(ps!=null)ps.close();}catch (SQLException e){e.printStackTrace();}try{if(conn!=null)conn.close();}catch (SQLException e){e.printStackTrace();}}

操作实现:

String sql1="delete from employees where employee_id=?";update(sql1,101);

总结

总的JDBC的常规操作就是以上的,首先我们需要导入我们需要的包,然后就是进行获取连接,然后得到连接之后我们就需要进行各种操作。希望对大家有所帮助。

浅谈JDBC,JDBC实现的几大步骤相关推荐

  1. 浅谈OpenCL之 应用程序总体步骤思路

    一般Opencl 应用程序步骤,为了保证原英文意思 没有翻译中文: 1:Query which platforms are present. 2:  Query the set of devices ...

  2. 浅谈手机直播系统开发流程步骤

    现在我们的生活每天都在跟手机上直播软件打交道,出现了直播购物.直播才艺.直播教育等等新事物,可以说直播已经融入我们生活中的方方面面,各个行业都想结合自家产业入局直播营销.但是对手机直播系统开发这个行业 ...

  3. 浅谈ERP实施应用的流程步骤

    公众号回复:干货,领取价值58元/套IT管理体系文档 公众号回复:ITIL教材,领取最新ITIL4中文教材 正文 导读:ERP系统,即企业资源计划,是指建立在信息技术基础上,集信息技术与先进管理思想于 ...

  4. 浅谈 JDBC 中 CreateStatement 和 PrepareStatement 的区别与优劣。

    浅谈 JDBC 中 CreateStatement 和 PrepareStatement 的区别与优劣.

  5. 浅谈JDBC与ODBC的区别与应用

    谈到JDBC与ODBC的区别,JDBC和ODBC其实都是用来连接数据库的启动程序.ODBC中文名字叫做开放数据库互联,是微软技术人员开发的开放服务结构中有关数据库的一个组成部分,它建立一组相关的规范, ...

  6. jdbc执行Statement接口的步骤

    jdbc执行Statement接口的步骤如下: 1)驱动注册程序: Class.forName(com.mysql.jdbc.Driver); 2)获取连接对象: Connection conn = ...

  7. android web 访问数据库,Web下的JDBC访问数据库的基本步骤

    Web下的JDBC访问数据库的基本步骤 (2012-06-02 12:09:33) 在Java程序中连接数据库的一般步骤分为一下几部分,我摘录出来,跟大家分享. (1)将数据库的JABC驱动加载到cl ...

  8. JDBC连接数据库的8个步骤

    package jdbcStudy;import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLExce ...

  9. 水晶报表 mysql_水晶报表CrystalReport2008使用JDBC连接MySQL数据库-详细步骤

    水晶报表CrystalReport2008使用JDBC连接MySQL数据库-详细步骤 一:前期准备工作 lCrystal Report 2008 lJDBC相关jar包 ---mysql-connec ...

  10. JDBC编程的六个步骤以及使用示例(详细)

    JDBC编程的六个步骤 1.注册驱动:通知Java程序我们要连接的是哪个品牌的数据库 2.获取数据库连接:Java进程和Mysql进程之间的通道开启了 3.获取数据库操作对象:这个对象是用来执行sql ...

最新文章

  1. Flutter开发之诊断布局调试工具:inspector(12)
  2. 如何用计算机输入数学公式,使用Win7输入面板让数学公式输入更轻松
  3. c 类别构造函数需要包含所有成员吗_C++默认成员函数解析
  4. Python第一天学习---基础语法
  5. xhost和XServer相关概念汇总
  6. 2021年Z世代“潮力量”洞察报告
  7. 江苏省有JAVA技能大赛,江苏省职业学校技能大赛组委会
  8. as3 与 java_每天学一点Flash(48) As3.0 与 java 通信(1)
  9. 需求跟踪矩阵模板_需求可追溯性矩阵(RTM)生成程序使用说明
  10. sqlserver 判断字段是否为空字符串或者null
  11. speak 计算机英语作文,跪求一篇英语作文 题目:论计算机的优缺点
  12. 在苹果Mac中将 WEBP 图片转成 JPG、PNG 格式的 2 种方法
  13. Julia: Flux.jl尝试
  14. 力扣14最长公共子串
  15. 解读中国版新资本协议
  16. VMware esxi-6.0root密码恢复和数据恢复
  17. Java单元测试之JUnit 5快速上手
  18. win10 屏幕保护程序“在恢复时显示登录屏幕”灰色
  19. opencv python 巡线 最小二乘法
  20. 40+倍提升,详解 JuiceFS 元数据备份恢复性能优化之路

热门文章

  1. usb接口供电不足_Win7系统下电脑USB供电不足的解决方法
  2. 环境搭建:使用python matplotlib画图不显示中文问题解决
  3. python打印经典故事从前有座山
  4. 用Oracle创建视图 ORA-01031:权限不足
  5. Oracle创建视图时显示没有权限
  6. 学计算机专业简历英语,计算机专业的英文简历.docx
  7. 不容错过的十大小米手机玩机技巧
  8. 沉迷抖音无法自拔?来看看你是不是掉入了它的陷阱!
  9. 小米商城侧边栏【显示向右箭头】
  10. el-table 去掉最下面的白线