孙肖宁

JDBC操纵数据库
概念JDBC(java database connectivity )SUN公司提供的一套操作数据库的标准规范。是...
扫描右侧二维码阅读全文
30
2018/01

JDBC操纵数据库

概念

JDBC(java database connectivity )SUN公司提供的一套操作数据库的标准规范。是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。

  • JDBC与数据库驱动的关系:接口与实现的关系。
  • JDBC规范(掌握四个核心对象):

    DriverManager:用于注册驱动
    Connection: 表示与数据库创建的连接
    Statement: 操作数据库sql语句的对象
    ResultSet: 结果集或一张虚拟表

  • 实现JDBC操作

    1、注册驱动
    2、创建连接
    3、得到执行sql语句的Statement对象
    4、执行sql语句,并返回结果
    5、处理结果
    6、关闭资源

常用的类和接口

java.sql.Drivermanager类

作用:创建连接

1.注册驱动

DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用
原因
导致驱动被注册2次,并且强烈依赖数据库的驱动jar
解决办法:Class.forName("com.mysql.jdbc.Driver");

2.与数据库建立连接
方式一:(常用)

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

试图建立到给定数据库 URL 的连接。
示例:
getConnection("jdbc:mysql://localhost:3306/user", "root", "root");
注意:
URL:SUN公司与数据库厂商之间的一种协议。
jdbc:mysql://localhost:3306/user
协议 子协议 IP :端口号 数据库
mysql: jdbc:mysql://localhost:3306/user 或者 jdbc:mysql:///user(默认本机连接)
oracle: jdbc:oracle:thin:@localhost:1521:sid

方式二:

Properties info = new Properties();//要参考数据库文档
info.setProperty("user", "root");
info.setProperty("password","root");
getConnection(String url, Properties info);
getConnection(String url);

方式三:

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

java.sql.Connection接口

作用:建立一个连接
注意:接口的实现在数据库驱动中。所有与数据库交互都是基于连接对象的。
方法:Statement createStatement(); //创建操作sql语句的对象

java.sql.Statement接口

作用:操作sql语句,并返回相应结果的对象
注意:接口的实现在数据库驱动中。用于执行静态 SQL 语句并返回它所生成结果的对象。
方法:
1.ResultSet executeQuery(String sql) 根据查询语句返回结果集。只能执行select语句。
2.int executeUpdate(String sql) 根据执行的DML(insert update delete)语句,返回受影响的行数。
3.boolean execute(String sql) 此方法可以执行任意sql语句。返回boolean值,表示是否返回ResultSet结果集。仅当执行select语句,且有返回结果时返回true, 其它语句都返回false;

注意:为防止SQL注入一般使用preparedStatement方法
preparedStatement:预编译对象, 是Statement对象的子类。
特点:

  • 性能要高;
  • 会把sql语句先编译;
  • sql语句中的参数会发生变化,过滤掉用户输入的关键字。

java.sql.ResultSet接口

作用:处理结果集
方法及作用

1.封装结果集的

  • 提供一个游标,默认游标指向结果集第一行之前。
  • 调用一次next(),游标向下移动一行。
  • 提供一些get方法。

封装数据的方法
Object getObject(int columnIndex); 根据序号取值,索引从1开始
Object getObject(String ColomnName); 根据列名取值。

2.将结果集中的数据封装到javaBean中

java的数据类型与数据库中的类型的关系

byte          tityint
short         smallint
int           int
long          bigint
float         float
double        double
String        char varchar 
Date         date

常用方法

  • boolean next()将光标从当前位置向下移动一行
  • int getInt(int colIndex)以int形式获取ResultSet结果集当前行指定列号值
  • int getInt(String colLabel)以int形式获取ResultSet结果集当前行指定列名值
  • float getFloat(int colIndex)以float形式获取ResultSet结果集当前行指定列号值
  • float getFloat(String colLabel)以float形式获取ResultSet结果集当前行指定列名值
  • String getString(int colIndex)以String 形式获取ResultSet结果集当前行指定列号值
  • String getString(String colLabel)以String形式获取ResultSet结果集当前行指定列名值
  • Date getDate(int columnIndex);以int形式获取Date结果集当前行指定列名值
  • Date getDate(String columnName); 以Date形式获取Date结果集当前行指定列名值
  • void close()关闭ResultSet 对象

可移动游标的方法

  • boolean next() 将光标从当前位置向前移一行。
  • boolean previous() 将光标移动到此 ResultSet 对象的上一行。
  • boolean absolute(int row) 参数是当前行的索引,从1开始,根据行的索引定位移动的指定索引行。
  • void afterLast() 将光标移动到末尾,正好位于最后一行之后。
  • void beforeFirst() 将光标移动到开头,正好位于第一行之前。

关闭资源

对象名.close();

注意:从小向大关闭。

Last modification:January 31st, 2018 at 11:11 am
If you think my article is useful to you, please feel free to appreciate

Leave a Comment