第二节——JDBC

JDBC学习

一、快速入门

  1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar,jar包下载地址:下载地址
    ------复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
    ------右键–>Add As Library
  2. 注册驱动
  3. 获取数据库连接对象 Connection
  4. 定义sql
  5. 获取执行sql语句的对象 Statement
  6. 执行sql,接受返回结果
  7. 处理结果
  8. 释放资源
//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:驱动管理对象

  1. 注册驱动:Class.forName(“com.mysql.jdbc.Driver”);通过这个语句将类加载进内存,该类的静态代码块会执行语句:static void registerDriver(Driver driver),注册与给定的驱动程序 DriverManager 。注意:mysql5之后的JDBCjar包可以省略此步骤
  2. 获取数据库连接:static Connection getConnection(String url, String user, String password)

三、Connection:数据库连接对象

  1. 获取执行sql 的对象
    * Statement createStatement()
    * PreparedStatement prepareStatement(String sql)
  2. 管理事务:
    * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务
    * 提交事务:commit()
    * 回滚事务:rollback()

四、Statement:执行sql的对象

  1. boolean execute(String sql) :可以执行任意的sql 了解
  2. int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句
    * 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。
  3. ResultSet executeQuery(String sql) :执行DQL(select)语句

五、ResultSet:结果集对象,封装查询结果

  1. boolean next(): 游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true

  2. getXxx(参数):获取数据。Xxx:代表数据类型 如: int getInt() , String getString()
    参数:
    int:代表列的编号,从1开始 如: getString(1)
    String:代表列名称。 如: getDouble(“balance”)

  3. 使用步骤:1)游标向下移动一行;2)判断是否有数据;3)获取数据。

六、举例

  1. 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();
  1. 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的对象

  1. 预编译的SQL,参数使用?作为占位符
  2. 获取执行sql语句的对象:PreparedStatement Connection.prepareStatement(String sql)
  3. 给?赋值:
    * 方法: setXxx(参数1,参数2),参数1:?的位置编号,从1 开始;参数2:?的值
  4. 执行sql
  5. 举例:
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();

猜你喜欢

转载自blog.csdn.net/qq_37589805/article/details/119793660