第二节——JDBC
Posted 想学习安全的小白
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第二节——JDBC相关的知识,希望对你有一定的参考价值。
JDBC学习
一、快速入门
- 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar,jar包下载地址:下载地址
------复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
------右键–>Add As Library - 注册驱动
- 获取数据库连接对象 Connection
- 定义sql
- 获取执行sql语句的对象 Statement
- 执行sql,接受返回结果
- 处理结果
- 释放资源
//1. 导入驱动jar包
//2.注册驱动
Class.forName("com.mysql.jdbc.Driver");
//3.获取数据库连接对象
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root");
//4.定义sql语句
String sql = "update account set balance = 500 where id = 1";
//5.获取执行sql的对象 Statement
Statement stmt = conn.createStatement();
//6.执行sql
int count = stmt.executeUpdate(sql);
//7.处理结果
System.out.println(count);
//8.释放资源
stmt.close();
conn.close();
二、DriverManager:驱动管理对象
- 注册驱动:Class.forName(“com.mysql.jdbc.Driver”);通过这个语句将类加载进内存,该类的静态代码块会执行语句:static void registerDriver(Driver driver),注册与给定的驱动程序 DriverManager 。注意:mysql5之后的JDBCjar包可以省略此步骤
- 获取数据库连接:static Connection getConnection(String url, String user, String password)
三、Connection:数据库连接对象
- 获取执行sql 的对象
* Statement createStatement()
* PreparedStatement prepareStatement(String sql) - 管理事务:
* 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务
* 提交事务:commit()
* 回滚事务:rollback()
四、Statement:执行sql的对象
- boolean execute(String sql) :可以执行任意的sql 了解
- int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句
* 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。 - ResultSet executeQuery(String sql) :执行DQL(select)语句
五、ResultSet:结果集对象,封装查询结果
-
boolean next(): 游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true
-
getXxx(参数):获取数据。Xxx:代表数据类型 如: int getInt() , String getString()
参数:
int:代表列的编号,从1开始 如: getString(1)
String:代表列名称。 如: getDouble(“balance”) -
使用步骤:1)游标向下移动一行;2)判断是否有数据;3)获取数据。
六、举例
- insert语句:
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://192.168.10.129:3306/test", "root", "970725");
Statement statement = con.createStatement();
String sql = "insert into ttable values(2,'qwe')";
int i = statement.executeUpdate(sql);
System.out.println(i);
statement.close();
con.close();
- select语句
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://192.168.10.129:3306/test", "root", "970725");
Statement statement = con.createStatement();
String sql = "select * from ttable";
ResultSet result = statement.executeQuery(sql);
result.next(); //光标先next到第二行才能获取数据,默认第一行是列的名称
int i = result.getInt(1); //获取第一行第一列的数据
String name = result.getString("name"); //获取第一行中name列的数据
System.out.println(i+":"+name);
statement.close();
con.close();
七、PreparedStatement:执行sql的对象
- 预编译的SQL,参数使用?作为占位符
- 获取执行sql语句的对象:PreparedStatement Connection.prepareStatement(String sql)
- 给?赋值:
* 方法: setXxx(参数1,参数2),参数1:?的位置编号,从1 开始;参数2:?的值 - 执行sql
- 举例:
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://192.168.10.129:3306/test", "root", "970725");
String sql = "select * from ttable where id=? or name =?"; //预编译SQL
PreparedStatement pre = con.prepareStatement(sql);
pre.setInt(1,1); //给预编译SQL赋值
pre.setString(2,"qwe");
ResultSet result = pre.executeQuery(); //执行SQL
result.next();
int i = result.getInt(1);
String name = result.getString("name");
System.out.println(i+":"+name);
pre.close();
con.close();
以上是关于第二节——JDBC的主要内容,如果未能解决你的问题,请参考以下文章