摘要:本文主要讲了如何使用Maven来搭建Spring+Mybatis+SpringMVC+MySql的搭建实例,文章写得很详细,有代码有图片,最后也带有运行的效果。

一、准备工作

1. 首先创建一个表:

CREATE TABLE `t_user` (

`USER_ID` int(11) NOT NULL AUTO_INCREMENT,

`USER_NAME` char(30) NOT NULL,

`USER_PASSWORD` char(10) NOT NULL,

`USER_EMAIL` char(30) NOT NULL,

PRIMARY KEY (`USER_ID`),

KEY `IDX_NAME` (`USER_NAME`)

) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8

随便插入一些数据:

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (1, '林炳文', '1234567@', 'ling20081005@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (2, 'evan', '123', 'fff@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (3, 'kaka', 'cadg', 'fwsfg@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (4, 'simle', 'cscs', 'fsaf@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (5, 'arthur', 'csas', 'fsaff@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (6, '小德', 'yuh78', 'fdfas@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (7, '小小', 'cvff', 'fsaf@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (8, '林林之家', 'gvv', 'lin@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (9, '林炳文Evankaka', 'dfsc', 'ling2008@126.com');

INSERT INTO t_user (USER_ID, USER_NAME, USER_PASSWORD, USER_EMAIL) VALUES (10, 'apple', 'uih6', 'ff@qq.com');

二、工程创建

1、Maven工程创建

(1)新建

(2)选择快速框架

(3)输出项目名,包,记得选war(表示web项目,以后可以spingMVC连起来用)

(4)创建好之后

目录如下:

(5)检查下

这三个地方JDK的版本一定要一样!!!!

三、sping+mybatis配置

1、整个工程目录如下:

2、POM文件

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

4.0.0

com.lin

ssm_project

0.0.1-SNAPSHOT

war

3.2.8.RELEASE

1.6.6

1.2.12

4.10

3.2.1

org.springframework

spring-core

${spring.version}

org.springframework

spring-webmvc

${spring.version}

org.springframework

spring-context

${spring.version}

org.springframework

spring-context-support

${spring.version}

org.springframework

spring-aop

${spring.version}

org.springframework

spring-aspects

${spring.version}

org.springframework

spring-tx

${spring.version}

org.springframework

spring-jdbc

${spring.version}

org.springframework

spring-web

${spring.version}

junit

junit

${junit.version}

test

log4j

log4j

${log4j.version}

org.slf4j

slf4j-api

${slf4j.version}

org.slf4j

slf4j-log4j12

${slf4j.version}

org.springframework

spring-test

${spring.version}

test

org.mybatis

mybatis

${mybatis.version}

org.mybatis

mybatis-spring

1.2.0

mysql

mysql-connector-java

5.1.29

3、java代码-------src/main/java

目录如下:

(1)User.java

对应数据库中表的字段,放在src/main/java下的包com.lin.domain

package com.lin.domain;

/**

* User映射类

*

* @author linbingwen

* @time 2015.5.15

*/

public class User {

private Integer userId;

private String userName;

private String userPassword;

private String userEmail;

public Integer getUserId() {

return userId;

}

public void setUserId(Integer userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

public String getUserPassword() {

return userPassword;

}

public void setUserPassword(String userPassword) {

this.userPassword = userPassword;

}

public String getUserEmail() {

return userEmail;

}

public void setUserEmail(String userEmail) {

this.userEmail = userEmail;

}

@Override

public String toString() {

return "User [userId=" + userId + ", userName=" + userName

+ ", userPassword=" + userPassword + ", userEmail=" + userEmail

+ "]";

}

}

(2)UserDao.java

Dao接口类,用来对应mapper文件。放在src/main/java下的包com.lin.dao,内容如下:

package com.lin.dao;

import com.lin.domain.User;

/**

* 功能概要:User的DAO类

*

* @author linbingwen

* @since 2015年9月28日

*/

public interface UserDao {

/**

*

* @author linbingwen

* @since 2015年9月28日

* @param userId

* @return

*/

public User selectUserById(Integer userId);

}

(2)UserService.java和UserServiceImpl.java

service接口类和实现类,放在src/main/java下的包com.lin.service,内容如下:

UserService.java

package com.lin.service;

import org.springframework.stereotype.Service;

import com.lin.domain.User;

/**

* 功能概要:UserService接口类

*

* @author linbingwen

* @since  2015年9月28日

*/

public interface UserService {

User selectUserById(Integer userId);

}

UserServiceImpl.java

package com.lin.service;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Service;

import com.lin.dao.UserDao;

import com.lin.domain.User;

/**

* 功能概要:UserService实现类

*

* @author linbingwen

* @since  2015年9月28日

*/

@Service

public class UserServiceImpl implements UserService{

@Autowired

private UserDao userDao;

public User selectUserById(Integer userId) {

return userDao.selectUserById(userId);

}

}

(4)mapper文件

用来和dao文件对应,放在src/main/java下的com.lin.mapper包下

mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

SELECT * FROM t_user WHERE USER_ID = #{userId}

4、资源配置-------src/main/resources

目录如下:

(1)mybatis配置文件

这里没有什么内容,因为都被放到application.xml中去了,放在src/main/resources下的mybatis文件夹下

mybatis-config.xml内容如下:

configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-config.dtd">

(2)数据源配置jdbc.properties

放在src/main/resources下的propertiesy文件夹下

jdbc_driverClassName=com.mysql.jdbc.Driver

jdbc_url=jdbc:mysql://localhost:3306/learning

jdbc_username=root

jdbc_password=christmas258@

(3)Spring配置

这是最重要的:application.xml内容如下

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"

xmlns:aop="http://www.springframework.org/schema/aop"

xsi:schemaLocation="

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.0.xsd">

classpath:properties/*.properties

class="org.springframework.jdbc.datasource.DriverManagerDataSource">

${jdbc_driverClassName}

${jdbc_url}

${jdbc_username}

${jdbc_password}

value="com.lin.dao" />

(4)日志打印log4j.properties

就放在src/main/resources

log4j.rootLogger=DEBUG,Console,Stdout

#Console

log4j.appender.Console=org.apache.log4j.ConsoleAppender

log4j.appender.Console.layout=org.apache.log4j.PatternLayout

log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n

log4j.logger.java.sql.ResultSet=INFO

log4j.logger.org.apache=INFO

log4j.logger.java.sql.Connection=DEBUG

log4j.logger.java.sql.Statement=DEBUG

log4j.logger.java.sql.PreparedStatement=DEBUG

log4j.appender.Stdout = org.apache.log4j.DailyRollingFileAppender

log4j.appender.Stdout.File = E://logs/log.log

log4j.appender.Stdout.Append = true

log4j.appender.Stdout.Threshold = DEBUG

log4j.appender.Stdout.layout = org.apache.log4j.PatternLayout

log4j.appender.Stdout.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

四、单元测试

上面的配置完好,接下来就是测验成功

整个目录 如下:

(1)测试基类

package com.lin.baseTest;

import org.junit.runner.RunWith;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.test.context.ContextConfiguration;

import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests;

import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

/**

* 功能概要:

*

* @author linbingwen

* @since  2015年9月28日

*/

//指定bean注入的配置文件

@ContextConfiguration(locations = { "classpath:application.xml" })

//使用标准的JUnit @RunWith注释来告诉JUnit使用Spring TestRunner

@RunWith(SpringJUnit4ClassRunner.class)

public abstract class SpringTestCase extends AbstractJUnit4SpringContextTests{

protected Logger logger = LoggerFactory.getLogger(getClass());

}

(2)测试类

package com.lin.service;

import org.apache.log4j.Logger;

import org.junit.Test;

import org.springframework.beans.factory.annotation.Autowired;

import com.lin.baseTest.SpringTestCase;

import com.lin.domain.User;

/**

* 功能概要:UserService单元测试

*

* @author linbingwen

* @since  2015年9月28日

*/

public class UserServiceTest extends SpringTestCase {

@Autowired

private UserService userService;

Logger logger = Logger.getLogger(UserServiceTest.class);

@Test

public void selectUserByIdTest(){

User user = userService.selectUserById(10);

logger.debug("查找结果" + user);

}

}

选中selectUserByIdTest,然后右键如下运行

输出结果:

重要打印的结果

这里

2015-09-28 15:20:15,129 [main] DEBUG [com.lin.dao.UserDao.selectUserById] - ==>  Preparing: SELECT * FROM t_user WHERE USER_ID = ?

2015-09-28 15:20:15,160 [main] DEBUG [com.lin.dao.UserDao.selectUserById] - ==> Parameters: 10(Integer)

2015-09-28 15:20:15,160 [main] DEBUG [org.mybatis.spring.SqlSessionUtils] - Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@6b64bff9]

2015-09-28 15:20:15,160 [main] DEBUG [org.springframework.jdbc.datasource.DataSourceUtils] - Returning JDBC Connection to DataSource

2015-09-28 15:20:15,160 [main] DEBUG [com.lin.service.UserServiceTest] - 查找结果User [userId=10, userName=apple, userPassword=uih6, userEmail=ff@qq.com]

数据库:

程序成功运行,并且结果正确!

到这里配置好spring+mybatis+mysql!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

=====================================================

这里开始添加spirngMVC,并转换maven工程为web项目

五、转换web工程

接上面的工程接着说,此时要加spingMVC之前,工程得再稍微转换下

此时webapp下的结果还没有显示出来,因为此时我们还没有配置此的项目为web项目

springmvc与mysql实例_Spring+Mybatis+SpringMVC+Maven+MySql搭建实例相关推荐

  1. spring mvc mysql 实例_Spring+Mybatis+SpringMVC+Maven+MySql搭建实例

    一.准备工作 1. 首先创建一个表: CREATE TABLE `t_user` ( `USER_ID` int(11) NOT NULL AUTO_INCREMENT, `USER_NAME` ch ...

  2. Maven-学习笔记06【基础-Maven工程servlet实例】

    Java后端 学习路线 笔记汇总表[黑马程序员] 黑马程序员(腾讯微云)Maven基础讲义.pdf Maven-学习笔记01[基础-Maven基本概念] Maven-学习笔记02[基础-Maven的安 ...

  3. Spring+Mybatis+SpringMVC+Maven+MySql(SSM框架)搭建实例

    这篇文章我们来实现使用maven构建工具来搭建Spring+Mybatis+SpringMVC+MySql的框架搭建实例.工程下载 使用maven当然得配置有关环境了,不会配置的请看我前几篇文章,都有 ...

  4. JAVA毕设项目html5在线医疗系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC)

    JAVA毕设项目html5在线医疗系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysql ...

  5. JAVA毕设项目公立医院绩效考核系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC)

    JAVA毕设项目公立医院绩效考核系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysql + ...

  6. JAVA毕设项目后勤管理系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC)

    JAVA毕设项目后勤管理系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysql + HBu ...

  7. JAVA毕设项目Web企业差旅在线管理系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC)

    JAVA毕设项目Web企业差旅在线管理系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysq ...

  8. JAVA毕设项目众筹网(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC)

    JAVA毕设项目众筹网(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysql + HBuild ...

  9. JAVA毕设项目-智慧农业水果销售系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC)

    JAVA毕设项目-智慧农业水果销售系统(Vue+Mybatis+Maven+Mysql+sprnig+SpringMVC) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysql ...

最新文章

  1. AI 3.0》王飞跃教授推荐序——未来智能:人有人用,机有机用
  2. css expressionr,CSS Expression讲解
  3. AGC002F - Leftmost Ball(dp,组合计数)
  4. python第六章函数课后答案_浙大PTA-Python题库 函数题(6-1~6-6)题解
  5. Python 中 xpath 语法 与 lxml 库解析 HTML/XML 和 CSS Selector
  6. GitHub 报告:中国755万开发者排全球第二
  7. 40行代码的人脸识别实践【转】
  8. Windows安装nginx服务
  9. c语言数组指针移位,C语言数组指针_3
  10. 线性代数第6章答案(仅供参考!!!)
  11. 在VMware虚拟机中安装Ubuntu教程
  12. JavaScript中this的指向 详解
  13. Vue中的Ajax(26th)
  14. gyb优化事项(1)
  15. macos修改WIFI共享功能的默认网段
  16. 二叉树的后序遍历(递归和非递归)
  17. [更新ing]sklearn(十六):Nearest Neighbors *
  18. 微信开发(一)--分享接口
  19. [ESP8266]刷MQTT固件以及连接服务器失败的问题解决
  20. 传感器(7)加速传感器,重力传感器,邻近传感器,光线传感器 综合示例

热门文章

  1. 活动安排问题的 动态规划和贪心算法
  2. php里面的 n算是,用PHP中的bcmath计算第N个根
  3. python安装cv2模块_python - OpenCV已成功安装但未导入错误:没有名为“ cv2”的模块 - 堆栈内存溢出...
  4. C++PrimerPlus学习——第九章编程练习
  5. com.alibaba.easyexcel导出指定的列_使用Python导入导出Excel表格
  6. python modulenotfounderror_python 服务器运行代码报错ModuleNotFoundError的解决办法
  7. react如何卸载组件_reactjs – 如何删除/卸载嵌套的反应组件
  8. c语言取子程序地址,哪位师傅知道51单片机怎样编写子程序?C语言的。在主程序里调...
  9. win7系统电脑运行速度的提升方法
  10. C++17新特性之std::string_view