JavaWeb 后端 <八> 之 JDBC基礎(全)

一、JDBC简介

1、JDBC是SUN公司为了简化操作数据推出一套规范。数据库厂商的驱动就是对JDBC的实现。

2、Java Data Base Connectivity(java数据库连接),它主要由接口组成。

  java.sql.*    javax.sql.*   JDK中

  数据库的驱动jar包 (mysql-connector-java-5.0.8-bin.jar )

二、JDBC的编码步骤

0、前提:拷贝数据库的驱动到构建路径中(classpath)

1、注册驱动

2、获取与数据库的链接

3、创建代表SQL语句的对象

4、执行SQL语句

5、如果是查询语句,需要遍历结果集

6、释放占用的资源

public class JdbcDemo1 {
 
  public static void main(String[] args) throws SQLException {
    // 1、注册驱动
    DriverManager.registerDriver(new com.mysql.jdbc.Driver());
    // 2、获取与数据库的链接
    Connection conn = DriverManager.getConnection(
            "jdbc:mysql://localhost:3306/day15", "root", ""); //没有密码则“” 空
    // System.out.println(conn.getClass().getName()); 要想知道具体类型,就这么办
    // 3、创建代表SQL语句的对象
    Statement stmt = conn.createStatement();
    // 4、执行SQL语句
    ResultSet rs = stmt.executeQuery("select id,name,password,email,birthday from users");
    // 5、如果是查询语句,需要遍历结果集
    while (rs.next()) {
        System.out.println("---------------------");
        System.out.println(rs.getObject("id"));
        System.out.println(rs.getObject("name"));
        System.out.println(rs.getObject("password"));
        System.out.println(rs.getObject("email"));
        System.out.println(rs.getObject("birthday"));
    }
    // 6、释放占用的资源
    rs.close();
    stmt.close();
    conn.close();
  }
}

三、JDBC中常用的接口详解

1、DriverManager:

  作用:

    a、注册驱动:

    方式一:(不建议使用)

    DriverManager.registerDriver(new com.mysql.jdbc.Driver());

    原因:1、依赖具体驱动。2、导致驱动注册2遍

    方式二:(建议)

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

 

    b、获取与数据库的链接

      url:SUN和数据库厂商间的协议。具体查阅数据库的文档。

      public static Connection getConnection(String url,String user,String password)

                                throws SQLException

      public static Connection getConnection(String url,Properties info)

                                throws SQLException

      public static Connection getConnection(String url)

                                throws SQLException

2、Connection

所有的数据库操作都是基于链接之上的。

Statement createStatement():创建向数据库发送sql的statement对象。

//2、获取与数据库的链接
//方式一:
//Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day15", "root", "sorry");
         
//方式二:
//Properties props = new Properties();
//props.setProperty("user", "root");//  参数名:参考数据库的文档
//props.setProperty("password", "sorry");
//props.setProperty("useUnicode", "true");//编码有关的参数
//props.setProperty("characterEncoding", "utf8");
//Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day15",props);
         
//方式三
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day15?user=root&password=sorry");
        

 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day15?user=root&password=");

3、Statement

Statement stmt = conn.createStatement();

作用:代表SQL语句对象。可以向数据库发送任何的SQL语句

ResultSet executeQuery(String sql):sql一般都是查询语句

int executeUpdate(String sql):sql一般是DML语句。insert update delete。返回值,操作几条记录。

boolean execute(String sql):sql可以是任意的语句。返回值不是代表成功与否。如果是查询语句,就有结果集,返回true。没有返回结果集的,返回false。

4、ResultSet

作用:封装了查询的结果集

ResultSet rs = stmt.executeQuery("select id,name,password,email,birthday from users");
List<User> users = new ArrayList<User>();
while(rs.next()){
  User user = new User();
  user.setId(rs.getInt("id"));
  user.setName(rs.getString("name"));
  user.setPassword(rs.getString("password"));
  user.setEmail(rs.getString("email"));
  user.setBirthday(rs.getDate("birthday"));
  users.add(user);
}

boolean next():游标下移。返回值是有无记录

boolean previous():游标上移。

boolean absolute(int count):定位到指定的行。第一行是1。

void beforeFirst():移动游标到第一行的前面。

void afterLast():移动游标到最后一行的后面。

四、释放占用的资源

//释放资源
//JDBC编码的代码模板
public class JdbcDemo5 {
public static void main(String[] args) {
    Connection conn = null;
    Statement stmt = null;
    ResultSet rs = null;
    try {
        Class.forName("com.mysql.jdbc.Driver");
        conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/day15", "root", "sorry");
        stmt = conn.createStatement();
        rs = stmt.executeQuery("select id,name,password,email,birthday from users");
        List<User> users = new ArrayList<User>();
        while (rs.next()) {
            User user = new User();
            user.setId(rs.getInt("id"));
            user.setName(rs.getString("name"));
            user.setPassword(rs.getString("password"));
            user.setEmail(rs.getString("email"));
            user.setBirthday(rs.getDate("birthday"));
            users.add(user);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } <br>      finally {
        if (rs != null) {
          try {
            rs.close();
          } catch (SQLException e) {
            e.printStackTrace();
           }
           rs = null;
        }
        if (stmt != null) {
          try {
            stmt.close();
          } catch (SQLException e) {
            e.printStackTrace();
          }
          stmt = null;
        }
        if (conn != null) {
          try {
            conn.close();
          } catch (SQLException e) {
            e.printStackTrace();
          }
          conn = null;
        }
    }
 
  }
 
}

五、JDBC进行CRUD(增刪改查)操作

工具類:

<strong><span style="color: #ff0000;">getConnection() return conn; 獲取連接<br><br>配置文件放在 dbcgf.properties 中<br><img src="" alt=""><br>release () 施放資源<br></span></strong>

//工具类
public class JdbcUtil {
     
private static String driverClass;
private static String url;
private static String user;
private static String password;
     
static{
  try {
    ClassLoader cl = JdbcUtil.class.getClassLoader();
    InputStream in = cl.getResourceAsStream("dbcfg.properties");
    Properties props = new Properties();
    props.load(in);
    driverClass = props.getProperty("driverClass");
    url = props.getProperty("url");
    user = props.getProperty("user");
    password = props.getProperty("password");
             
    Class.forName(driverClass);
    } catch (Exception e) {
        throw new ExceptionInInitializerError(e);
        }
    }
     
    public static Connection getConnection() throws Exception{
      Connection conn = DriverManager.getConnection(url,user, password);
      return conn;
    }
    public static void release(ResultSet rs,Statement stmt,Connection conn){
      if(rs!=null){
        try {
          rs.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
          rs = null;
        }
        if(stmt!=null){
        try {
              stmt.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
          stmt = null;
        }
        if(conn!=null){
        try {
          conn.close();
        ] catch (SQLException e) {
            e.printStackTrace();
        }
          conn = null;
        }
    }
}

 測試:

package com.yif.jdbc;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
 
import org.junit.Test;
import com.yif.util.JdbcUtil;
 
public class JdbcDemo6 {
    @Test
      public void testAdd(){
      Connection conn = null;
      Statement stmt = null;
      ResultSet rs = null;
      try{
        conn = JdbcUtil.getConnection();
        stmt = conn.createStatement();
        stmt.executeUpdate("insert into users (name,password,email,birthday) values ('范青霞','123','fqx@itcast.cn','2000-10-01')");
      }catch(Exception e){
        throw new RuntimeException(e);
      }finally{
        JdbcUtil.release(rs, stmt, conn);
      }
    }
    @Test
    public void testUpdate(){
      Connection conn = null;
      Statement stmt = null;
      ResultSet rs = null;
      try{
        conn = JdbcUtil.getConnection();
        stmt = conn.createStatement();
        stmt.executeUpdate("update users set password=111 where id=4");
      }catch(Exception e){
        throw new RuntimeException(e);
      }finally{
        JdbcUtil.release(rs, stmt, conn);
      }
    }
    @Test
    public void testDelete(){
      Connection conn = null;
      Statement stmt = null;
      ResultSet rs = null;
      try{
        conn = JdbcUtil.getConnection();
        stmt = conn.createStatement();
        stmt.executeUpdate("delete from users where id=1");
      }catch(Exception e){
        throw new RuntimeException(e);
      }finally{
        JdbcUtil.release(rs, stmt, conn);
      }
    }
}

sql 注入 :

1、用户的表单输入域:防止一些特殊字符。

2、对密码加密:MD5加密

 

PreparedStatement接口

1、支持SQL的预编译。得到该对象时,就必须给他SQL语句。

2、支持参数占位符:  ?  一个问号代表着一个参数。

 

注:能用PreparedStatement就不要用Statement。

时间: 2024-08-08 14:11:24

JavaWeb 后端 <八> 之 JDBC基礎(全)的相关文章

JavaWeb 后端 &lt;九&gt; 之 JDBC加强

一.大结果集的分页(重点,难点) 1.分批次查询:分页 2.基于数据库的分页:依赖的是数据库的分页语句(不同数据库是不同的) MySQL:每页显示10条.   select * from XXX limit M,N; M:开始记录的索引.第一条记录的索引为0. N:一次查询几条记录.   第一页:select * from CUSTOMERS limit 0,10; 第二页:select * from CUSTOMERS limit 10,10;  ...... 第n页:select * fro

JavaWeb 后端 &lt;一&gt; 之 Tomcat服务器 - Http协议 学习笔记

1.Web开发概述 1.1服务器上的资源分类: a.静态资源:指web页面中供人们浏览的数据始终是不变.html css js 图片 多媒体 b.动态资源:指web页面中供人们浏览的数据是由程序产生的,不同时间点访问web页面看到的内容各不相同.JSP/Servlet.php.asp 下面为简单的java程序 模拟服务器提供资源 访问 本地端口1111即可得到服务器的资源 public class Myserver {     public static void main(String[] a

JavaWeb 后端 &lt;四&gt; 之 Cookie HttpSession 学习笔记

一.会话管理概述 1.什么是会话? 好比一次通话.打开浏览器,点击多次链接(发出多次请求和收到多次的响应),关闭浏览器,这个过程就是一次会话. 有功能 可以  文件 新建会话   2.解决的问题是什么? 共享多次请求中产生的数据.比如购物车. 二.客户端技术:Cookie 0.HTTP协议的消息头 请求消息头:Cookie 客户端向服务器端传递信息 响应消息头:Set-Cookie 服务器端向客户端传递信息 1.Cookie详解: l  属性: name:Cookie的名称,必要的属性 valu

MySQL数据库学习笔记(八)----JDBC入门及简单增删改数据库的操作

[正文]                                                                                                                                              一.JDBC的引入                                                                                               

JavaWeb 后端 &lt;十四&gt; 文件上传下载

1.文件上传与下载 案例:          注册表单/保存商品等相关模块!          --à 注册选择头像 / 商品图片          (数据库:存储图片路径 / 图片保存到服务器中指定的目录) 1.1 文件上传 文件上传,要点: 前台:          1. 提交方式:post          2. 表单中有文件上传的表单项: <input type="file" />          3. 指定表单类型:                    默认类

JavaWeb 后端 &lt;五&gt; 之 JSP 学习笔记

一.JSP简介 1.也是SUN公司推出的开发动态web资源的技术,属于JavaEE技术之一.由于原理上是Servlet, 所以JSP/Servlet在一起. 二.HTML.Servlet和JSP 1.HTML:静态页面,不能包含java代码,只能有HTML有关的标记 2.Servlet:写java代码,做页面的输出,不是很方便(开发效率很低) 3.JSP:HTML+java 三.输出当前的时间 <%@ page language="java" import="java.

JavaWeb 后端 &lt;十一&gt; 之 DBUtils 框架 (基本使用 结果集 事务处理 对表读取)

一.数据库操作框架 1.ORM:Object Relation Mapping Hibernate:非常流行 JPA:Java Persistent API.ORM标准 MyBatis:2010年开始.之前叫做iBatis(重视) 2.JDBC封装框架 DBUtils Spring JDBC Template 二.Apache的DBUtils框架(会用:练习作业) 1.基本的使用 DBCPutil public class DBCPUtil {     private static DataSo

JavaWeb 后端 &lt;二&gt; 之 Servlet 学习笔记

 一.Servlet概述 1.什么是Servlet Servlet是一个运行在服务器端的Java小程序,通过HTTP协议用于接收来自客户端请求,并发出响应. 2.Servlet中的方法 public void service(ServletRequest req,ServletResponse res) throws ServletException,java.io.IOException   ServletRequest req:代表着请求对象,该对象中有HTTP协议的请求部分的所有内容.它的

JavaWeb 后端 &lt;十三&gt; 之 监听器 JSTL国际化

1. 监听器 1.1   概述 监听器: 主要是用来监听特定对象的创建或销毁.属性的变化的!                     是一个实现特定接口的普通java类! 对象:          自己创建自己用 (不用监听)          别人创建自己用 (需要监听)   Servlet中哪些对象需要监听?          request / session / servletContext          分别对应的是request监听器.session相关监听器.servletCo