为什么一些小型项目中,我还是会推荐使用JdbcTemplate?

大部分人刚开始学Java的时候,都是使用Jdbc连接数据库,其实Jdbc已经能够满足我们大部分的基础需求,但是使用Jdbc有一点不好,就是麻烦,必须创建大量的冗余代码,必须自己来管理数据库资源,比如创建连接,关闭连接,处理异常,获取PreparedStatement,设置SQL语句参数等等,虽然操作简单,但是效率着实不高。


所以,新入职的同事在做一个demo的时候,我就强烈地推荐他使用JdbcTemplate,使用JdbcTemplate可节省大量的冗余代码,让使用者只需关注业务逻辑即可。

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

/**
 * 提供连接
 */
public class DruidUtils {

	private static DataSource dataSource = null;

	static { // 必须优先执行 只执行一次

		try {
			// 需要一个文件流
			InputStream is = DruidUtils.class.getClassLoader().getResourceAsStream("db.properties");
			// 创建配置文件对象
			Properties props = new Properties();
			props.load(is);
			// 核心类
			dataSource = DruidDataSourceFactory.createDataSource(props);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * 返回数据源方法
	 * 
	 * @return
	 */
	public static DataSource getDataSource() {
		return dataSource;
	}

	/**
	 * 提供连接的方法
	 * 
	 * @return
	 */
	public static Connection getConnection() throws SQLException {

		return dataSource.getConnection();
	}
}
// 使用示例
JdbcTemplate template = new JdbcTemplate(DruidUtils.getDataSource());
String sql = "SELECT MAX(qi_hao) FROM " + dataTableName;

Object max = template.queryForObject(sql, String.class);
maxQiHao = String.valueOf(max);

你看,只要把连接封装为DruidUtils公共方法,增删改查用起来就相当地简单,那么,JdbcTemplate的一些常用方法有哪些呢?JdbcTemplate主要提供:
1)execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;

void execute(DDL的SQL语句);//数据库表的创建

JdbcTemplate template = new JdbcTemplate(DruidUtils.getDataSource());
		template.execute(
				"CREATE TABLE user (id int(11) NOT NULL AUTO_INCREMENT,username varchar(50) DEFAULT NULL,PRIMARY KEY (id)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8");

2)update方法及batchUpdate方法:
    update方法用于执行新增、修改、删除等语句;
    batchUpdate方法用于执行批处理相关语句;

JdbcTemplate template = new JdbcTemplate(DruidUtils.getDataSource());

		String hql = "UPDATE user SET username='张三' WHERE username='李四'";
		int aa = template.update(hql);
		/**
		 * 注:使用批量更新需根据具体情况选择不同参数
		 */
		int[] cc = template.batchUpdate("UPDATE user SET username='张三' WHERE username=?", "李四");

3)query方法及queryForXXX方法:用于执行查询相关语句;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;

import com.xf.jc.util.DruidUtils;

public class Test {
	public static void main(String[] args) {
		JdbcTemplate template = new JdbcTemplate(DruidUtils.getDataSource());
		/**
		 * 查询单个字段值
		 */
		String s = template.queryForObject("select username from user where id=?", String.class, 3);
		Integer s2 = template.queryForObject("select id from user where id=?", Integer.class, 4);

		/**
		 * 使用queryForObject方法和BeanPropertyRowMapper做映射还可以查询一个具体类对象
		 */
		User user = template.queryForObject("select * from user where id=?",
				new BeanPropertyRowMapper<User>(User.class), 3);

		/**
		 * 查询单条记录
		 */
		Map<String, Object> map = template.queryForMap("SELECT * FROM user WHERE id=?", 3);

		/**
		 * 查询多条记录
		 */
		List<Map<String, Object>> maps = template.queryForList("SELECT * FROM user");

		/**
		 * 查询多条记录用RowMapper做映射成对象
		 */
		List<User> query = template.query("select * from user where id in(?,?)", new RowMapper<User>() {
			@Override
			public User mapRow(ResultSet resultSet, int i) throws SQLException {
				int id = resultSet.getInt("id");
				String username = resultSet.getString("uname");
				User user = new User(id, username);
				return user;
			}
		}, 3, 4);

		/**
		 * 查询多条记录用BeanPropertyRowMapper做映射成对象
		 */
		List<User> use = template.query("select * from user where id in(?,?)",
				new BeanPropertyRowMapper<User>(User.class), 3, 4);
	}
}

4)call方法:用于执行存储过程、函数相关语句。


 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JdbcTemplate是Spring框架提供的一个用于简化数据库操作的工具类。它封装了JDBC的细节,提供了一组简洁的API来执行SQL语句并处理结果集。下面是使用JdbcTemplate进行数据库操作的基本步骤: 1. 配置数据源:在Spring配置文件配置数据源,例如使用`org.springframework.jdbc.datasource.DriverManagerDataSource`类配置一个基于驱动程序管理的数据源。 2. 创建JdbcTemplate对象:在Spring配置文件创建一个`org.springframework.jdbc.core.JdbcTemplate`对象,并将数据源注入到该对象。 3. 编写SQL语句:根据需求编写SQL语句,可以使用占位符来代替参数。 4. 执行SQL语句:使用JdbcTemplate对象的方法执行SQL语句,例如`update()`方法用于执行INSERT、UPDATE和DELETE语句,`query()`方法用于执行SELECT语句。 5. 处理结果集:根据需要处理查询结果集,可以使用`RowMapper`接口来映射每一行的数据到Java对象。 下面是一个简单的示例代码: ```java import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; public class UserDao { private JdbcTemplate jdbcTemplate; public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } public void addUser(User user) { String sql = "INSERT INTO user (id, name, age) VALUES (?, ?, ?)"; jdbcTemplate.update(sql, user.getId(), user.getName(), user.getAge()); } public User getUserById(int id) { String sql = "SELECT * FROM user WHERE id = ?"; RowMapper<User> rowMapper = new UserRowMapper(); return jdbcTemplate.queryForObject(sql, rowMapper, id); } } class User { private int id; private String name; private int age; // 省略getter和setter方法 } class UserRowMapper implements RowMapper<User> { @Override public User mapRow(ResultSet rs, int rowNum) throws SQLException { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setAge(rs.getInt("age")); return user; } } ``` 以上代码演示了如何使用JdbcTemplate进行数据库操作,包括插入数据和查询数据。你可以根据具体的需求进行扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值