使用SpringMVC轻松处理多种数据库 (springmvc处理数据库)

随着互联网的发展和数据量的不断增加,各种数据库也应运而生。其中常见的关系型数据库有MySQL、Oracle、SQL Server等,非关系型数据库有MongoDB、Redis等。在实际的项目开发中,我们往往需要同时连接和操作多个不同类型的数据库。SpringMVC提供了强大的数据访问层支持,能够轻松处理多种数据库,本文将介绍如何使用SpringMVC实现多种数据库的连接和操作。

1. 引入SpringMVC数据访问支持

在项目中引入SpringMVC数据访问支持,需要在pom.xml文件中添加对应依赖。以下是集成MySQL、Oracle、SQL Server和MongoDB的依赖:

“`

org.springframework

spring-jdbc

5.1.8.RELEASE

mysql

mysql-connector-java

8.0.13

com.oracle

ojdbc6

11.2.0.3

com.microsoft.sqlserver

mssql-jdbc

7.0.0.jre8

org.springframework.data

spring-data-mongodb

2.1.7.RELEASE

org.mongodb

mongodb-driver-sync

3.12.2

“`

其中,spring-jdbc是Spring JDBC的核心包,包含了Spring JDBC的所有功能。mysql-connector-java是MySQL的Java驱动。ojdbc6是Oracle的Java驱动。 mssql-jdbc是SQL Server的Java驱动。spring-data-mongodb是Spring封装的操作MongoDB的Java包。mongodb-driver-sync是MongoDB的Java驱动。

2. 配置数据源

在配置文件中添加数据源相关信息。以下是MySQL、Oracle、SQL Server和MongoDB的配置示例:

MySQL:

“`

spring.datasource.url=jdbc:mysql://localhost:3306/test

spring.datasource.username=root

spring.datasource.password=123456

spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver

“`

Oracle:

“`

spring.datasource.url=jdbc:oracle:thin:@localhost:1521:XE

spring.datasource.username=system

spring.datasource.password=123456

spring.datasource.driverClassName=oracle.jdbc.driver.OracleDriver

“`

SQL Server:

“`

spring.datasource.url=jdbc:sqlserver://localhost:1433;databaseName=test

spring.datasource.username=sa

spring.datasource.password=123456

spring.datasource.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver

“`

MongoDB:

“`

spring.data.mongodb.uri=mongodb://localhost:27017/test

“`

3. 编写Dao层代码

创建对应的Dao类,在其中提供操作数据库的方法,实现数据的增删改查等操作。以下是MySQL、Oracle、SQL Server和MongoDB的Dao类示例:

MySQL:

“`

@Repository

public class UserDao {

@Autowired

JdbcTemplate jdbcTemplate;

public List findAll() {

return jdbcTemplate.query(“select * from user”, new BeanPropertyRowMapper(User.class));

}

public void add(User user) {

jdbcTemplate.update(“insert into user (name, age) values (?, ?)”, user.getName(), user.getAge());

}

public void delete(long id) {

jdbcTemplate.update(“delete from user where id = ?”, id);

}

public void update(User user) {

jdbcTemplate.update(“update user set name = ?, age = ? where id = ?”, user.getName(), user.getAge(), user.getId());

}

}

“`

Oracle:

“`

@Repository

public class UserDao {

@Autowired

JdbcTemplate jdbcTemplate;

public List findAll() {

return jdbcTemplate.query(“select * from \”user\””, new BeanPropertyRowMapper(User.class));

}

public void add(User user) {

jdbcTemplate.update(“insert into \”user\” (name, age) values (?, ?)”, user.getName(), user.getAge());

}

public void delete(long id) {

jdbcTemplate.update(“delete from \”user\” where id = ?”, id);

}

public void update(User user) {

jdbcTemplate.update(“update \”user\” set name = ?, age = ? where id = ?”, user.getName(), user.getAge(), user.getId());

}

}

“`

SQL Server:

“`

@Repository

public class UserDao {

@Autowired

JdbcTemplate jdbcTemplate;

public List findAll() {

return jdbcTemplate.query(“select * from [user]”, new BeanPropertyRowMapper(User.class));

}

public void add(User user) {

jdbcTemplate.update(“insert into [user] (name, age) values (?, ?)”, user.getName(), user.getAge());

}

public void delete(long id) {

jdbcTemplate.update(“delete from [user] where id = ?”, id);

}

public void update(User user) {

jdbcTemplate.update(“update [user] set name = ?, age = ? where id = ?”, user.getName(), user.getAge(), user.getId());

}

}

“`

MongoDB:

“`

@Repository

public class UserDao {

@Autowired

private MongoTemplate mongoTemplate;

public List findAll() {

return mongoTemplate.findAll(User.class);

}

public void add(User user) {

mongoTemplate.save(user);

}

public void delete(User user) {

mongoTemplate.remove(user);

}

public void update(User user) {

mongoTemplate.save(user);

}

}

“`

其中,JdbcTemplate是Spring提供的JDBC模板,能够简化JDBC的操作。BeanPropertyRowMapper是Spring提供的一个实现了ResultSetExtractor接口的类,能够将一个ResultSet对象转换成一个Java对象。MongoTemplate是Spring封装的操作MongoDB的类。

4. 编写Service层代码

创建对应的Service类,在其中调用Dao层提供的方法,实现业务逻辑的处理。以下是MySQL、Oracle、SQL Server和MongoDB的Service类示例:

MySQL:

“`

@Service

public class UserService {

@Autowired

UserDao userDao;

public List findAll() {

return userDao.findAll();

}

public void add(User user) {

userDao.add(user);

}

public void delete(long id) {

userDao.delete(id);

}

public void update(User user) {

userDao.update(user);

}

}

“`

Oracle:

“`

@Service

public class UserService {

@Autowired

UserDao userDao;

public List findAll() {

return userDao.findAll();

}

public void add(User user) {

userDao.add(user);

}

public void delete(long id) {

userDao.delete(id);

}

public void update(User user) {

userDao.update(user);

}

}

“`

SQL Server:

“`

@Service

public class UserService {

@Autowired

UserDao userDao;

public List findAll() {

return userDao.findAll();

}

public void add(User user) {

userDao.add(user);

}

public void delete(long id) {

userDao.delete(id);

}

public void update(User user) {

userDao.update(user);

}

}

“`

MongoDB:

“`

@Service

public class UserService {

@Autowired

UserDao userDao;

public List findAll() {

return userDao.findAll();

}

public void add(User user) {

userDao.add(user);

}

public void delete(User user) {

userDao.delete(user);

}

public void update(User user) {

userDao.update(user);

}

}

“`

5. 编写Controller层代码

创建对应的Controller类,在其中调用Service层提供的方法,实现接口的处理。以下是MySQL、Oracle、SQL Server和MongoDB的Controller类示例:

MySQL:

“`

@RestController

public class UserController {

@Autowired

UserService userService;

@GetMapping(“/user”)

public List findAll() {

return userService.findAll();

}

@PostMapping(“/user”)

public void add(@RequestBody User user) {

userService.add(user);

}

@DeleteMapping(“/user/{id}”)

public void delete(@PathVariable(“id”) long id) {

userService.delete(id);

}

@PutMapping(“/user”)

public void update(@RequestBody User user) {

userService.update(user);

}

}

“`

Oracle:

“`

@RestController

public class UserController {

@Autowired

UserService userService;

@GetMapping(“/user”)

public List findAll() {

return userService.findAll();

}

@PostMapping(“/user”)

public void add(@RequestBody User user) {

userService.add(user);

}

@DeleteMapping(“/user/{id}”)

public void delete(@PathVariable(“id”) long id) {

userService.delete(id);

}

@PutMapping(“/user”)

public void update(@RequestBody User user) {

userService.update(user);

}

}

“`

SQL Server:

“`

@RestController

public class UserController {

@Autowired

UserService userService;

@GetMapping(“/user”)

public List findAll() {

return userService.findAll();

}

@PostMapping(“/user”)

public void add(@RequestBody User user) {

userService.add(user);

}

@DeleteMapping(“/user/{id}”)

public void delete(@PathVariable(“id”) long id) {

userService.delete(id);

}

@PutMapping(“/user”)

public void update(@RequestBody User user) {

userService.update(user);

}

}

“`

MongoDB:

“`

@RestController

public class UserController {

@Autowired

UserService userService;

@GetMapping(“/user”)

public List findAll() {

return userService.findAll();

}

@PostMapping(“/user”)

public void add(@RequestBody User user) {

userService.add(user);

}

@DeleteMapping(“/user”)

public void delete(@RequestBody User user) {

userService.delete(user);

}

@PutMapping(“/user”)

public void update(@RequestBody User user) {

userService.update(user);

}

}

“`

6. 测试接口

启动项目,在浏览器或Postman中访问接口,测试数据的增删改查功能。以下是MySQL、Oracle、SQL Server和MongoDB的测试接口:

MySQL:

“`

GET http://localhost:8080/user

POST http://localhost:8080/user Body: {“name”:”tom”,”age”:18}

PUT http://localhost:8080/user Body: {“id”:1,”name”:”tom”,”age”:19}

DELETE http://localhost:8080/user/1

“`

Oracle:

“`

GET http://localhost:8080/user

POST http://localhost:8080/user Body: {“name”:”tom”,”age”:18}

PUT http://localhost:8080/user Body: {“id”:1,”name”:”tom”,”age”:19}

DELETE http://localhost:8080/user/1

“`

SQL Server:

“`

GET http://localhost:8080/user

POST http://localhost:8080/user Body: {“name”:”tom”,”age”:18}

PUT http://localhost:8080/user Body: {“id”:1,”name”:”tom”,”age”:19}

DELETE http://localhost:8080/user/1

“`

MongoDB:

“`

GET http://localhost:8080/user

POST http://localhost:8080/user Body: {“name”:”tom”,”age”:18}

PUT http://localhost:8080/user Body: {“id”:”5e6cef61f6fb8a43b0e6b9a9″,”name”:”tom”,”age”:19}

DELETE http://localhost:8080/user Body: {“id”:”5e6cef61f6fb8a43b0e6b9a9″,”name”:”tom”,”age”:18}

“`

相关问题拓展阅读:

  • springmvc+mybatis怎么使用线程进行数据库操作

springmvc+mybatis怎么使用线程进行数据库操作

首先,你的确定数据的主键是否可以返配使用序列自增。

  如果可以那么你可以在插入数察纯据的时候获取序列里的值,这样数据就不会重复了。

其次,可以创建一个公共方漏没指法,进行数据的插入操作,并且方法类型声明为 static synchronized

  类型,这样基本上就不会出现数据重复的现象了

最后,要看你是怎么获得待插入源数据了,这个获得数据源的方法也做成static synchronized的公

  共方法。

关于springmvc处理数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/256529.html<

(0)
运维的头像运维
上一篇2025-05-01 08:36
下一篇 2025-05-01 08:38

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注