mybatis+springmvc框架反射获取dao类

正常情况下,我们通过反射获取一个类对象是这样的:
Class boClass = Class.forName("类名");
Object bsabo = boClass.newInstance();

但是在使用mybatis框架的时候,dao类通常都是interface接口,这样获取会报错。作为一只刚开始使用mybatis框架的菜鸟,能模仿着使用,然而并不了解mybatis框架的原理,后来看到了这篇文章http://blog.csdn.net/mingtian625/article/details/47684271,在那篇文章中有句话“spring+mybatis注解方式,也是没有实现类的,但是spring会默认返回MapperFactoryBean对象作为实现类的替换”。所以可以利用框架现有的机制,从而得到dao类对象

Class testDao = Class.forName("类名");
SqlSession session = sqlSessionFactory.openSession();  
  Object mapper = session.getMapper(testDao);  

好的,我可以为您提供一个简单的Spring+MyBatis+SpringMVC框架实现项目实验学习心得的例子,供您参考。 首先,我们需要创建一个Maven项目,并且在pom.xml文件中添加Spring、MyBatisSpringMVC的依赖项。 ```xml <!-- Spring --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.3.8</version> </dependency> <!-- MyBatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.7</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>2.0.6</version> </dependency> <!-- SpringMVC --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.3.8</version> </dependency> ``` 接下来,我们需要创建一个Spring配置文件 applicationContext.xml 并配置数据源、MyBatis和事务管理器。 ```xml <!-- 数据源配置 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean> <!-- MyBatis配置 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="typeAliasesPackage" value="com.example.model"/> <property name="mapperLocations" value="classpath:mappers/*.xml"/> </bean> <!-- 事务管理器配置 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <!-- 开启注解事务 --> <tx:annotation-driven transaction-manager="transactionManager"/> ``` 然后,我们需要创建一个SpringMVC配置文件 spring-mvc.xml 并配置视图解析器、静态资源映射和控制器映射。 ```xml <!-- 视图解析器配置 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/"/> <property name="suffix" value=".jsp"/> </bean> <!-- 静态资源映射配置 --> <mvc:resources mapping="/resources/**" location="/resources/"/> <!-- 控制器映射配置 --> <context:component-scan base-package="com.example.controller"/> <mvc:annotation-driven/> ``` 现在,我们可以创建一个数据表,并且编写一个Java和一个Mapper文件来操作它。 ```java // Java package com.example.model; public class User { private int id; private String name; private int age; // getter和setter方法 } // Mapper文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.mapper.UserMapper"> <resultMap id="userMap" type="com.example.model.User"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="age" column="age"/> </resultMap> <select id="getUserById" resultMap="userMap"> SELECT * FROM user WHERE id = #{id} </select> </mapper> ``` 接下来,我们可以创建一个控制器来处理用户请求,调用Java和Mapper文件来操作数据。 ```java package com.example.controller; import com.example.mapper.UserMapper; import com.example.model.User; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; @Controller @RequestMapping("/user") public class UserController { @Autowired private UserMapper userMapper; @RequestMapping(value = "/{id}", method = RequestMethod.GET) public String getUserById(@PathVariable int id, Model model) { User user = userMapper.getUserById(id); model.addAttribute("user", user); return "user"; } } ``` 最后,我们可以创建一个JSP文件来展示用户信息。 ```jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>User Info</title> </head> <body> <h1>User Info</h1> <p>ID: ${user.id}</p> <p>Name: ${user.name}</p> <p>Age: ${user.age}</p> </body> </html> ``` 这样,我们就完成了一个简单的Spring+MyBatis+SpringMVC框架实现的项目实验学习心得。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值