JDBC 概述

什么是JDBC

是一种用于执行SQL语句的Java API,它由一组用Java语言编写的类和接口组成,JDBC提供了一种操作数据的标准,JDBC的目标是使Java程序员使用JDBC可以连接任何提供了JDBC驱动程序的数据库系统。

通过驱动连接

JDBC的API

java.sql包装的就是JDBC的API。各大数据库厂商就会对JDBC的API提供实现类——驱动包。注意不要引错包。

连接Mysql

1. 添加驱动

  1. 在项目当中创建一个文件夹为lib
  2. 把Mysql驱动包复制到该文件夹下
  3. builder path 编译路径

2. 创建连接

eclipse 中查看驱动相关api:ctrl+shift+t 查找 drive 点进去后, 要求关联源码,把驱动压缩包直接关联。

1. 加载驱动

把com.mysql.jdbc.Driver这份字节码加载进 JVM,当一份字节码被加载到 JVM 时,就会执行该字节码中的静态代码块:

  1. static {
  2. try {
  3. java.sql.DriverManager.registerDriver(new Driver());
  4. } catch (SQLException E) {
  5. throw new RuntimeException("Can't register driver!");
  6. }
  7. }

代码实现:

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

2. 获取连接对象

连接时要求传入数据库地址、用户名、密码

  1. String url = "jdbc:mysql://localhost:3306/new";
  2. String user = "root";
  3. String password = "abcd";
  4. Connection conn = DriverManager.getConnection(url, user, password);

查看连接数( SHOW PROCESSLIST )

3. 创建并执行sql语句

数据库SQL结构化语言:

  1. 数据查询语言(DQL: Data Query Language)
  1. SELECT <字段名> FROM <表或视图名> WHERE <查询条件>;
  1. 数据操纵语言(DML:Data Manipulation Language)
  1. INSERT INTO <表名>(列1,列2,...) VALUES (值1,值2,...);
  2. UPDATE <表名> SET <列名>=新值 WHERE <列名>=某值;
  3. DELETE FROM <表名> WHERE <列名>=某值;
  1. 数据定义语言(DDL:Data Definition Language)

CREATE、ALTER、DROP,用于在数据库中创建新表或删除表,以及为表加入索引等。

  1. 数据控制语言(DCL:Data Control Language)

通过GRANT、DENT、REVOKE,确定单个用户或用户组对数据库对象的访问权限。

Statement接口作用:用于进行Java程序和数据库之间的数据传输。

具体类有3个实现:

1. Statement

用于对数据库进行通用访问,使用的是静态sql。

  1. String sql = "DML/DDL";
  2. Statement st = conn.createStatement();
  3. int row = st.executeUpdate(sql);
2. PreparedStatement

用于预编译模板SQL语句,在运行时接受sql输入参数。

预编译语句:

没有预编译语句时,所有的sql都是进行拼接:

  1. String sql = "insert into stu values("+stu.getId()+",'"+stu.getName()+"'")";

PreparedStatement 用于预编译模板SQL语句,在性能和代码灵活性上有显著地提高。PreparedStatement 对象使用 ? 作为占位符,即参数标记;使用 setXXX( index,value) 方法将值绑定到参数中,每个参数标记是其顺序位置引用,注意 index 从 1 开始;

PreparedStatement 对象执行SQL语句:(注意,它们都没有参数)

  • executeQuery()
  • executeUpdate()
SQL注入

就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。

用户登入示例:

预编译语句可以防SQL注入,所以更安全。之所以PreparedStatement能防止注入,是因为它把单引号转义了,变成了 \',这样一来,就无法截断SQL语句,进而无法拼接SQL语句 基本上没有办法注入了。

  1. String sql = "insert into student(name,age) values(?,?)";
  2. PreparedStatement ps = conn.prepareStatement(sql);
  3. ps.setString(1, stu.getName());
  4. ps.setInt(2, stu.getAge());
  5. ps.executeUpdate();
3. CallableStatement

要访问数据库存储过程时使用,也可以接受运行时输入参数。

4.处理结果集

结果集 ResultSet:表示数据库查询的结果的集合,在执行查询语句时就会得到一个这样的结果。

常用方法:

  • boolean next():判断是否有下一行数据。若有,则向下移动一行指针。

  • getXxx(int columnIndex):获取当前行中,第几列 (从1开始),(不推荐)

  • getXxx(String columnName):获取当前行中,指定列名的列的值。columnName是列名/列的别名。

    若列的类型是VARCHAR/CHAR/TEXT,都使用getString来获取列的值。

    若列的类型是int/integer,都使用getInt来获取列的值。

Mysql与Java数据类型对照表:

3. 释放数据资源

  1. if (rs != null) {
  2. try {
  3. rs.close();
  4. } catch (SQLException e) {
  5. e.printStackTrace();
  6. }
  7. }
  8. if (st != null) {
  9. try {
  10. st.close();
  11. } catch (SQLException e) {
  12. e.printStackTrace();
  13. }
  14. }
  15. if (conn != null) {
  16. try {
  17. conn.close();
  18. } catch (SQLException e) {
  19. e.printStackTrace();
  20. }
  21. }

JDBC 编程初步的更多相关文章

  1. 浅谈JDBC编程

    一.概述 1.为什么要用JDBC 数据库是程序不可或缺的一部分,每一个网站和服务器的建设都需要数据库.对于大多数应用程序员(此处不包含数据库开发人员)来说,我们更多的不是在DBMS中对数据库进行操纵, ...

  2. 单独使用jdbc编程问题总结(一)

    在学习Mybatis之前,我们先来回顾JDBC编程的相关知识.在此基础上深入的学习Mybatis框架.如有错误,敬请指正. (一)首先我们既然要使用jdbc,当然是要操作数据库了.创建一个名为:myb ...

  3. 02Mybatis_原生态jdbc编程中的问题总结——从而引生出为什么要用Mybatis

    我们先用jdbc去编写一个例子: 第一步:建表 /* SQLyog v10.2 MySQL - 5.1.72-community : Database - mybatis ************** ...

  4. JDBC编程的方式

    JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: 从上面可以看出JDBC编程一般要如下步骤: 1. 加载数据库驱动 2. 创建并获取数据库连接 3. 创建jdbc stateme ...

  5. JAVA基础知识之JDBC——编程步骤及执行SQL

    JDBC编程步骤 下面以mysql数据库为例, 1.加载驱动 首先需要下载数据库的驱动jar文件,并且在eclipse包中加入到class path中去, 例如mysql的驱动文件 mysql-con ...

  6. JDBC编程 之 增删改查

    JDBC编程之数据增加,更改,查询,删除 package com.good.jdbc; import java.sql.Connection; import java.sql.DriverManage ...

  7. JDBC编程步骤

    JDBC编程步骤 加载数据库驱动. 通常使用Class类的forName()静态方法来加载驱动. Class.forName(driverClass) dirverClass: mysql---Cla ...

  8. 【Java】JDBC编程套路

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5847020.html 学习Java开发,一个必须掌握的知识点,就是数据库操作.当程序需要用到的数据达到一定程度 ...

  9. 用JDBC编程的执行时错误及其解决大全

    用JDBC编程的执行时错误及其解决 用JDBC编程的执行时错误及其解决 源码: .java.lang.ClassNotFoundException: com.microsoft.jdbc.sqlser ...

随机推荐

  1. Git 常用命令(二)

    用 git init 在目录中创建新的 Git 仓库.  $ mkdir test $ cd test/ $ git init Initialized empty Git repository in ...

  2. eclipse执行maven install命令时跳过test

    在pom.xml里面配置一下代码,将跳过test. <plugins> <plugin> <groupId>org.apache.maven.plugins< ...

  3. CTSC/APIO2018 帝都一周游

    day0 报道 上午早早就起来了,两点才到酒店,然后去简单试了试机子. 不得不说今年八十中的伙食变得瓜皮了啊,去年还是大叠的5元卷,今年变成了单张的*餐卷.不知道食堂吝啬什么,面条米饭都只有一点点,还 ...

  4. shell下在while循环中使用ssh命令的问题

    1 现象描述 最近使用ssh批量执行命令(已经做了密钥互信了),脚本读取配置文件中的主机列表(内容为每行一台主机IP地址),然后执行,可是每次只是执行第一台,就退出循环了. 2 排查思路 由于脚本比较 ...

  5. 【Windows使用笔记】Windows日常使用软件

    整理一些对于我来说日常使用的Windows软件. 排名不分先后,仅凭我想起来的顺序! 1 MadAppLauncher 这个对我来说非常需要了. 使用它可以快速启动日常常用的软件,非常快捷高效.一般来 ...

  6. mysql查询语句的执行顺序(重点)

    一 SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOI ...

  7. Linux进程调度与源码分析(三)——do_fork()的实现原理

    用户层的fork(),vfork(),clone()API函数在执行时,会触发系统调用完成从用户态陷入到内核态的过程,而上述函数的系统调用,最终实现都是通过内核函数do_fork()完成,本篇着重分析 ...

  8. monkey测试===Monkey测试结果分析(系列三)转

    Monkey测试结果分析 一. 初步分析方法: Monkey测试出现错误后,一般的差错步骤为以下几步: 1. 找到是monkey里面的哪个地方出错 2. 查看Monkey里面出错前的一些事件动作,并手 ...

  9. Oracle 内存顾问

    --查看内存相关参数SYS@ test10g> col name for a30SYS@ test10g> col value for a20SYS@ test10g> select ...

  10. HTML5API(5)

    一.SVG 1.svg与canvas的区别 canvas绘制的是位图,svg绘制的是矢量图 canvas使用JavaScript绘制,svg使用xml绘制 canvas不能给每个图形绑定事件,svg可 ...