oracle中getnum,oracle学习笔记(六) JDBC使用

JDBC使用

1. 导包

直接使用IDEA导入依赖包即可

新建一个lib,把jar包放在这里

%E5%A4%96%E9%93%BE%E7%BD%91%E5%9D%80%E5%B7%B2%E5%B1%8F%E8%94%BD

2. 加载驱动

Class.forName("oracle.jdbc.driver.OracleDriver");

3. 创建Connection对象

连接数据库,从而获得Connection对象

String url = "jdbc:oracle:thin:@localhost:1521:ORCL";//具体的实例名可以查看自己的服务管理,有个

Connection conn = DriverManager.getConnection(url,"scott","tiger");//后面的两个参数分别为连接数据库的用户名和密码

PS:查看实例名

开始->运行->输入services.msc

%E5%A4%96%E9%93%BE%E7%BD%91%E5%9D%80%E5%B7%B2%E5%B1%8F%E8%94%BD

找到服务

%E5%A4%96%E9%93%BE%E7%BD%91%E5%9D%80%E5%B7%B2%E5%B1%8F%E8%94%BD

后面的就是我们的oracle数据库的实例名

4. 创建Statement对象

Statement stmt = conn.createStatement();

Statement: 普通语句类型,只能执行一条完整的语句

PreparedStatement: 预编译语句,它支持占位符“?”, 如:select * from emp WHERE ename LIKE ? and sal>?

CallableStatement: 支持存储过程的调用

PreparedStatement和CallableStatement都是继承Statement,比Statement要强大

补充链接(暂时未写):

PreparedStatement的使用

CallableStatement的使用

5. 执行SQL语句

//执行查询语句,会返回有个结果集ResultSet

ResultSet rs = stmt.executeQuery("select * from student");

6. 使用ResultSet获取数据库数据

//遍历结果集, 每次调用next方法时会使结集的游标后移,最初游标位于第一行之前

//Student累是我们写的一个bean类,就是把数据库中的每一条数据当作为一个对象,每一列都当作为Student类的属性

while (rs.next()){

//第循环一次封装一条记录

Student student = new Student();

student.setNum(rs.getInt("num"));

student.setName(rs.getString("name"));

//获取其它字段rs.getXxx("列名") Xxx表示相应的数据类型

//或者也可以re.getXxx(int columnNum) 参数为第几列

//如果不知道列的具体类型,也可以使用rs.getObject

}

oracle与java的类型对应

oracle

java

varchar/varchar(2)

String

int

int

number

double

date

date

7. 关闭

依次关闭ResultSet Statement Connection

补充

一般将连接方法和关闭方法封装为静态方法调用,连接方法和关闭方法封装在JdbcUtil工具类中

开启数据库链接的三个参数一般我们不会更改,所以我们直接写死在资源文件里面

设置编码UTF-8,使用中文字符就会自动转为Unicode

%E5%A4%96%E9%93%BE%E7%BD%91%E5%9D%80%E5%B7%B2%E5%B1%8F%E8%94%BD

一般写在与src同目录,代码如下

jdbc.url = jdbc:oracle:thin:@localhost:1521:ORCL jdbc.driver = oracle.jdbc.driver.OracleDriver jdbc.username = stars jdbc.password = stars

%E5%A4%96%E9%93%BE%E7%BD%91%E5%9D%80%E5%B7%B2%E5%B1%8F%E8%94%BD

写一个Dao类,其中有update,save,delete,find等方法,从而实现对数据库的增删改查

JdbcUtil工具类:

package homework;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import java.util.ResourceBundle;

/**

* @author StarsOne

* @date Create in 2019/4/24 0024 22:18

* @description

*/

class JdbcUtil {

private static final String DRIVER = getValue("jdbc.driver");

private static final String URL = getValue("jdbc.url");

private static final String USERNAME = getValue("jdbc.username");

private static final String PASSWORD = getValue("jdbc.password");

static{

try {

//注册数据库驱动程序

Class.forName(DRIVER);

} catch (ClassNotFoundException e) {

System.err.println("注册数据库驱动程序失败。" + e.getMessage());

}

}

/**

* 获取数据库连接

* @return 一个Connection

*/

public static Connection getConnection() {

try {

Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);

return conn;

} catch (SQLException e) {

System.err.println("a获得数据连接失败。" + e.getMessage());

}

return null;

}

/**

* 关闭

* @param conn

* @param stmt

* @param rs

*/

public static void close(Connection conn, Statement stmt, ResultSet rs) {

try {

//关闭数据库的资源的顺序最好与使用的顺序相反

if(rs != null){

rs.close();

}

if(stmt != null){

stmt.close();

}

if(conn != null){

conn.close();

}

} catch (SQLException e) {

e.printStackTrace();

}

}

/**

* 读取属性文件中的信息

*

* @param key

* @return

*/

private static String getValue(String key) {

// 资源包绑定

ResourceBundle bundle = ResourceBundle.getBundle("jdbc");

return bundle.getString(key);

}

public static void main(String[] args) {

System.out.println(getValue("jdbc.driver"));

System.out.println(getConnection());

}

}

StudentDao.java

我的代码还没有补全,使用的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 findAll() {

List 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;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值