直接使用IDEA导入依赖包即可 新建一个lib,把jar包放在这里
连接数据库,从而获得Connection对象
复制String url = "jdbc:oracle:thin:@localhost:1521:ORCL";//具体的实例名可以查看自己的服务管理,有个 Connection conn = DriverManager.getConnection(url,"scott","tiger");//后面的两个参数分别为连接数据库的用户名和密码PS:查看实例名
开始->运行->输入services.msc找到服务后面的就是我们的oracle数据库的实例名PreparedStatement和CallableStatement都是继承Statement,比Statement要强大补充链接:PreparedStatement的使用CallableStatement的使用(待补充)
oracle与java的类型对应
oraclejavavarchar/varchar(2)Stringintintnumberdoubledatedate依次关闭ResultSet Statement Connection
ResourceBundle文件一般要在src同目录,否则会出现java.lang.NoClassDefFoundError异常,代码如下
复制jdbc.url = jdbc:oracle:thin:@localhost:1521:ORCL jdbc.driver = oracle.jdbc.driver.OracleDriver jdbc.username = stars jdbc.password = stars 复制 ResourceBundle bundle = ResourceBundle.getBundle("资源文件名"); String s = bundle.getString("keyName");//getString("username").. }写一个Dao类,其中有update,save,delete,find等方法,从而实现对数据库的增删改查
我的代码还没有补全,使用的Statement语句
复制package homework; import java.sql.Connection; import java.sql.Date; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.List; /** * @author StarsOne * @date Create in 2019/4/24 0024 22:24 * @description */ class StudentDao { /** * 添加一个 * @param student */ public void save(Student student) { String name = student.getName(); int num = student.getNum(); Connection connection = null; Statement statement = null; try { connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //拼接SQL语句,把数据插入到数据库中 statement.execute("insert into STUDENT value(" + num + "," + name + ") "); } catch (SQLException e) { e.printStackTrace(); } finally { JdbcUtil.close(connection, statement, null); } } public void update(Student student) { } /** * 删除指定编号的学生 * @param num */ public void delete(Integer num) { Connection connection = null; Statement statement = null; try { connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //拼接SQL语句,把数据插入到数据库中 boolean flag = statement.execute("delete from STUDENT where num = " + num); if (flag) { System.out.println("删除成功!"); } else { System.out.println("删除失败!"); } } catch (SQLException e) { e.printStackTrace(); } finally { JdbcUtil.close(connection, statement, null); } } /** * 主键查询 * @param number */ public void findByPK(Integer number) { Connection connection = null; Statement statement = null; ResultSet resultSet=null; try { connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //查询query,返回一个数据集 resultSet = statement.executeQuery("select * from STUDENT where num =" + number); while (resultSet.next()) { int num = resultSet.getInt("num"); String name = resultSet.getString("name"); String sex = resultSet.getString("sex"); int age = resultSet.getInt("age"); Date birthdate = resultSet.getDate("birthdate"); double grade = resultSet.getDouble("grade"); //新建一个对象 new Student(num, age, grade, name, sex, birthdate); } } catch (SQLException e) { e.printStackTrace(); } finally { JdbcUtil.close(connection, statement, resultSet); } } /** * 查询全部 * @return */ public List<Student> findAll() { List<Student> list = new ArrayList<>(); Connection connection = null; Statement statement = null; ResultSet resultSet=null; try { connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //查询query,返回一个数据集 resultSet = statement.executeQuery("select * from STUDENT" ); while (resultSet.next()) { int num = resultSet.getInt("num"); String name = resultSet.getString("name"); String sex = resultSet.getString("sex"); int age = resultSet.getInt("age"); Date birthdate = resultSet.getDate("birthdate"); double grade = resultSet.getDouble("grade"); //新建一个对象 list.add(new Student(num, age, grade, name, sex, birthdate)); } } catch (SQLException e) { e.printStackTrace(); } finally { JdbcUtil.close(connection, statement, resultSet); } return list; } }转载于:https://www.cnblogs.com/chaoyang123/p/11549351.html
相关资源:JAVA上百实例源码以及开源项目