<!-- MyBatis配置 这个就是spring和mybatis的整合 也就是spring-mybatis jar--> <bean id="mysqlSqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!--数据库 多数据源配置多个--> <property name="dataSource" ref="mysqlDataSource" /> <!-- 自动扫描mapping.xml文件 --> <!-- 自动扫描entity目录, 省掉xml里的手工配置 该属性可以给包中的类注册别名,注册后可以直接使用类名,而不用使用全限定的类名--> <property name="typeAliasesPackage" value="com.springmvc.model" /> <!-- mysqlSqlSessionFactory会自动扫描该路径下的所有文件并解析。--> <property name="mapperLocations"> <list> <value>classpath:/mybatis/*Mapper.xml</value> </list> </property> </bean> <!--会查找类路径下的映射器并自动将它们创建成MapperFactoryBean --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="sqlSessionFactoryBeanName" value="mysqlSqlSessionFactory"></property> <!-- 为映射器接口文件设置基本的包路径 --> <property name="basePackage" value="com.springmvc.dao" /> <!-- 该属性起到一个过滤的作用,设置该属性,那么mybatis的dao接口 只有包含该注解 才会被扫描--> <property name="annotationClass" value="com.springmvc.base.JYBatis"/> </bean>
/**
* 标识MyBatis的DAO,方便{@link org.mybatis.spring.mapper.MapperScannerConfigurer}的扫描�??
*
* 总的来说就是 target(接口) retention(java-class后依旧可用) document(包含在javadoc中) component(spring扫描)
*/
@Retention(RetentionPolicy.RUNTIME) //注解的生命周期 这个是最长的 jvm加载class文件之后,仍然存在
@Target(ElementType.TYPE) //注解修改目标 (这是个接口) 接口、类、枚举、注解
@Documented //该注解将被包含在javadoc中
@Component //@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
public @interface JYBatis {
String value() default "";
}
db.username=root db.password=123456 db.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8 db.dirverClass=com.mysql.jdbc.Driver
<form action="spring/student/testController" method="post"> <br />用户名: <input type="text" name="name"> <br /> <br />年龄: <input type="text" name="age"> <br /> <br /> 老师: <input type="text" name="teacher"> <br /> <input type="submit" value="登录"> </form>
//Alias是mybatis给当前model类起的别名 typeAlias
@Alias("Student")
public class Student {
private int id;
private String name;
private int age;
private String teacher;
@Controller
@RequestMapping("/spring/student")
public class StudentController {
@Resource
private StudentService ss;
@RequestMapping(value="/testController")
public String toPage(Student s){
System.out.println(s.toString());
s.setId(33);
ss.save(s);
return "success";
}
}
public interface StudentService {
public void save(Student student);
}
//StudentServiceImpl 这里要加上注解
@Service("StudentService")
public class StudentServiceImpl implements StudentService {
@Autowired
private StudentDao studentDao;
@Override
public void save(Student student) {
studentDao.insert(student);
}
@JYBatis
public interface StudentDao {
public void insert(Student student);
}
<?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.springmvc.dao.StudentDao">
<!-- com.jy.entity.system.account.Account -->
<!-- com.jy.entity.oa.leave.Leave -->
<resultMap id="base" type="Student" > </resultMap>
<select id="find" resultMap="base" parameterType="Student">
SELECT t.* FROM user1 t WHERE 1=1
<if test="id != null and id!='' ">
AND t.id=#{id}
</if>
</select>
<select id="count" resultType="int" parameterType="Student">
SELECT count(*) FROM user1 t WHERE 1=1
</select>
<insert id="insert" parameterType="Student">
<![CDATA[
INSERT INTO user1(
id,
age,
name,
teacher
) VALUES (
#{id},
#{age},
#{name},
#{teacher}
)
]]>
</insert>
<update id="updateUserAssetInfo" parameterType="Map">
UPDATE user1
SET
id=#{id},
age=#{age},
name=#{name},
teacher=#{teacher}
WHERE id=#{id}
</update>
</mapper>
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有