JDBC(二)
重载:
方法重载是让类以统一的方式处理不同类型数据的一种手段。多个同名函数同时存在,具有不同的参数个数/类型。重载Overloading是一个类中多态性的一种表现。
Java的方法重载,就是在类中可以创建多个方法,它们具有相同的名字,但具有不同的参数和不同的定义。
调用方法时通过传递给它们的不同参数个数和参数类型来决定具体使用哪个方法, 这就是多态性。
(3) 重载的时候,方法名要一样,但是参数类型和个数不一样,返回值类型可以相同也可以不相同。无法以返回型别作为重载函数的区分标准。
重写:
父类与子类之间的多态性,对父类的函数进行重新定义。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。在Java中,子类可继承父类中的方法,而不需要重新编写相同的方法。
但有时子类并不想原封不动地继承父类的方法,而是想作一定的修改,这就需要采用方法的重写。方法重写又称方法覆盖。
(2)若子类中的方法与父类中的某一方法具有相同的方法名、返回类型和参数表,则新方法将覆盖原有的方法。
如需父类中原有的方法,可使用super关键字,该关键字引用了当前类的父类。
(3)子类函数的访问修饰权限不能少于父类的;
- 驱动:driver
- 设置驱动点:DriverManager
- 属性(集合类):Properties
- 类加载器:Classloadr
- 获取属性:getProperties
- 连接:Connection
- 获取连接:getConnection
JDBC工具类:
package jdbcutils.gj; import java.io.FileReader; import java.io.IOException; import java.net.URL; import java.sql.*; import java.util.Properties; //JDBC 工作类 public class JdbcUtils { /* 获取连接, * */ //定义数据 static String url = null; static String user = null; static String password = null; static String driver = null; static { //静态代码块、读取配置文件 //1、properties 集合类 Properties pro = new Properties();//定义一个新的属性 //2、加载文件 try { //路径不能写死, //Classloadr 类加载器 ClassLoader classLoader = JdbcUtils.class.getClassLoader();//定一个新的类加载器 //动态获取路径 URL resoure = classLoader.getResource("jdbc.properties");//获取网址 pro.load(new FileReader(resoure.getPath()));//加载新的动态路径 } catch (IOException e) {//异常 e.printStackTrace(); } //3、获取数据 url = pro.getProperty("url"); user = pro.getProperty("user"); password = pro.getProperty("password"); driver = pro.getProperty("driver"); //4、注册驱动 try { Class.forName(driver);//driver:驱动 } catch (ClassNotFoundException e) { e.printStackTrace(); } } static public Connection getconection() throws SQLException { //不能写死 return DriverManager.getConnection(url, user, password); } // 释放 public static void close(Statement sta, Connection conn) { if (sta != null) { try { sta.close();//关闭 } catch (SQLException throwables) { throwables.printStackTrace(); } } if (conn != null) { try { conn.close();// 关闭 } catch (SQLException throwables) { throwables.printStackTrace(); } } } public static void close(ResultSet re, Statement sta, Connection conn) { if (re != null) { try { re.close();//关闭 } catch (SQLException e) { e.printStackTrace(); } } if (sta != null) { try { sta.close();//关闭 } catch (SQLException throwables) { throwables.printStackTrace(); } } if (conn != null) { try { conn.close();//关闭 } catch (SQLException throwables) { throwables.printStackTrace(); } } } }
登录系统主程序:
package jdbcutils; import jdbcutils.gj.JdbcUtils; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.Scanner; public class 登录系统 { public static void main(String[] args) { // 1、录入 用户驶入的用户名和密码 Scanner sc = new Scanner(System.in); System.out.println("请输入用户名"); String username = sc.nextLine(); System.out.println("请输入密码"); String password = sc.nextLine(); // 2、调用方法 boolean flag = new 登录系统().login(username, password); System.out.println(flag); // 判断输出的是否正确,是否登录成功 if (flag) { System.out.println("登录成功"); } else { System.out.println("用户名或密码错误"); } } // 登录方法 public boolean login(String username, String password) { // 判断密码和用户名是否有数据 if (username == null || password == null) { return false; } // 连接 Connection conn = null; // SQL语句 PreparedStatement preparedStatement = null; // 接口 ResultSet resultSet = null; try { // 连接工具类获取里面的数据 conn = JdbcUtils.getconection(); // 定义sql命令 String sql = "SELECT * FROM login WHERE user = ? AND password=?"; // 执行sql preparedStatement = conn.prepareStatement(sql); // 把输入的数据变成SQL语句命令 preparedStatement.setString(1, username); preparedStatement.setString(2, password); // 执行SQL命令 resultSet = preparedStatement.executeQuery(); //返回执行后的 return resultSet.next(); // 异常 } catch (SQLException e) { e.printStackTrace(); } finally {// 释放 JdbcUtils.close(resultSet, preparedStatement, conn);//工具类执行完毕关闭 } return false; } }