欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

使用JDBC连接数据库

程序员文章站 2022-04-30 11:56:58
...

JDBC是Java数据库连接技术,他能实现Java程序对各种数据库的访问。由一组使用Java语言编写的类和接口组成,他们位于java.sql和javax.sql中。 JDBC是一种用于执行SQL语句的java API,JDBC并不能直接访问数据库,需要依赖于数据库厂商提供的JDBC驱动程序。 JDB

JDBC是Java数据库连接技术,他能实现Java程序对各种数据库的访问。由一组使用Java语言编写的类和接口组成,他们位于java.sql和javax.sql中。

JDBC是一种用于执行SQL语句的java API,JDBC并不能直接访问数据库,需要依赖于数据库厂商提供的JDBC驱动程序。

JDBC的编程步骤如下:

1、通过Class.forName();注册驱动。

2、通过DriverManager类的getConnection()方法获得数据库连接。需要给出连接数据库的URL和数据库用户名和密码。

3、用数据库连接对象获得Statement对象,他可以用来执行SQL语句。

4、用Statement对象执行SQL语句。实质上SQL语句是数据库执行的,Statement只是负责发送SQL和接受结果。

5、处理执行结果。查询结果为ResultSet。

6、释放数据库的连接。

因为在开发和部署时可能用到不同的数据库,因此我们可以讲数据库信息写在配置文件中,让程序通过读取配置文件来获得这些信息。

下面看一个示例:

首先看数据库(这里使用Oracle数据库):

使用JDBC连接数据库

该数据库公有7个字段,id字段是主键,代表新闻编号;title字段表示新闻标题;summary字段代表新闻摘要,content代表新闻内容;createdate表示新闻创建时间;mindifydate代表新闻最终修改时间。

然后在看java项目中的配置文件。在此之前需要在项目中导入Oracle数据库的驱动包ojdbc14.jar。

jdbc.driver_class=oracle.jdbc.driver.OracleDriver
jdbc.connection.url=jdbc\:oracle\:thin\:@localhost\:1521\:ORCL
jdbc.connection.username=myhr
jdbc.connection.password=myhr

然后看读取数据库配置文件的工具类。

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;


public class ConfigManager {
	private static ConfigManager configManager;//声明ConfigManager对象
	private static Properties properties;//声明Properties对象
	
	private ConfigManager(){
		String configPath = "database.properties";
		properties = new Properties();
		InputStream in = ConfigManager.class.getResourceAsStream(configPath);
		try {
			properties.load(in);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	
	private static ConfigManager getInstance(){
		if(configManager == null){
			configManager = new ConfigManager();
		}
		return configManager;
	}
	
	public String getString(String key){
		return properties.getProperty(key);
	}
}

然后看数据库操作代码,看JDBC如何具体操作数据库

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Timestamp;
import java.util.Date;

public class NewsDao {
	Connection connection = null;
	Statement statement = null;
	PreparedStatement pstmt = null;
	ResultSet rs = null;
	//建立与数据库之间的连接
	public void getConnection(){
		//调用工具类的相应方法,得到配置文件中的信息
		String driver = ConfigManager.getInstance().getString("jdbc.driver_class");
		String url = ConfigManager.getInstance().getString("jdbc.connection.url");
		String username = ConfigManager.getInstance().getString("jdbc.connection.username");
		String password = ConfigManager.getInstance().getString("jdbc.connection.password");
		try {
			//使用Class.froName方法加载驱动类
			Class.forName(driver);
			//DriverManager类的getConnection方法建立于数据库连接
			connection = DriverManager.getConnection(url, username, password);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
	//查询新闻
	public void getNewsList(){
		getConnection();
		String sql = "select * from news";
		try {
			//获得Statement对象
			statement = connection.createStatement();
			//执行SQL语句并得到ResultSet
			rs = statement.executeQuery(sql);
			//处理执行结果
			while(rs.next()){
				int id = rs.getInt("id");
				String title = rs.getString("title");
				String summary = rs.getString("summary");
				String content = rs.getString("content");
				String author = rs.getString("author");
				Timestamp time = rs.getTimestamp("createdate");
				Timestamp last = rs.getTimestamp("MIDIFYDATE");
				System.out.println("新闻id:"+id+" 标题:"+title+" 摘要:"+summary
			+" 内容:"+content+" 作者:"+author+" 创建时间:"+time+" 修改时间:"+last);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}finally{
			try {
				rs.close();
				statement.close();
				connection.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
			
		}
	}
	//添加新闻信息
	public void add(int id,String title,String summary,String content,
			String author,Date createdate,Date last){
		getConnection();
		String sql = "insert into news values(?,?,?,?,?,?,?)";
		try {
			pstmt = connection.prepareStatement(sql);
			pstmt.setInt(1, id);
			pstmt.setString(2, title);
			pstmt.setString(3, summary);
			pstmt.setString(4, content);
			pstmt.setString(5, author);
			pstmt.setTimestamp(6, new java.sql.Timestamp(createdate.getTime()));
			pstmt.setTimestamp(7, new java.sql.Timestamp(last.getTime()));
			int i = pstmt.executeUpdate();//i表示插入的行数
			if(i>0)
				System.out.println("插入成功!");
			else
				System.out.println("插入失败!");
		} catch (SQLException e) {
			e.printStackTrace();
		}finally{
			try {
				pstmt.close();
				connection.close();
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}
		
	}
	
}

然后看测试类

import java.util.Date;


public class Test {
	public static void main(String[] args) {
		NewsDao nd = new NewsDao();
		nd.getNewsList();
		nd.add(2, "有蚊子", "今天竟然有蚊子", "今天竟然真的有蚊子,咬了我好几口!",
				"admin", new Date(), new Date());
	}
}

程序正常运行。