环境
- windows 10 64
- java 1.7
- tomcat 7
工具
- eclipse
框架
- springmvc + spring + mybatis
- 整个框架帮我们完成了 web 的搭建
java web 开发中的 概念
controller : 接受 处理 浏览器发来的请求
service:实现一些具体的业务
dao: 负责和 数据库打交道
配置tomcat
eclipse => perferences=>server=>runenviroment =>add
配置lab库
eclipse => perferences=>java=>build-path=>user librarties
创建java web项目
file => new =>other
-
添加项目信息
-
出现以下提示是因为eclispe 检测到你创建了一个 javaee的项目,会建议你切换到javaee 的编辑模式!
导入spring配置包
添加依赖库
右键项目> perferences=>build-path=>user librarties=>library =>add library=>user library
'
结果图:
修改配置信息
- 修改数据库链接信息
#jdbc.driver=com.mysql.jdbc.Driver
jdbc.driver=oracle.jdbc.OracleDriver
jdbc.url=jdbc:oracle:thin:@127.0.0.1:1521:daily
jdbc.username=erhuan
jdbc.password=Huanuo2017
省略了spring mvc , spring, mybtis 整合过程
编写controler
- 创建包
- 修改配置文件中的 包名
2. 创建一个包
右键 src=> new package (包名为配置文件中的 包名)
- 开始代码编写
- 创建一个controler
取名规则:Xxx Controller
代码:
package cn.nokia.controller;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
/**
* @controler 的作用是 ssm框架扫描到该关键字 会知道这个类的作用
* @author fan
*
*/
@Controller
public class HellowController {
/**
* @ResponseBody 配置返回的数据为 json
* @return
*/
@RequestMapping("index")
public @ResponseBody List doindex() {
// TODO Auto-generated method stub
List<Map<String, String> > list = new ArrayList<>();
Map<String, String> map = new HashMap<>();
map.put("name", "NAME");
map.put("age", "24");
list.add(map);
return list;
}}
service
-
创建包
配置文件
- 接口代码
取名规则 XxxsSrvice
package cn.nokia.service;
import java.util.List;
public interface HellowService {
public List doHello();
}
- 实现类代码
package cn.nokia.service.impl;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.stereotype.Service;
import cn.nokia.service.HellowService;
/**
* @service("实例名") 告诉 ssm 这个是service
* @author fan
*
*/
@Service("helloservice")
public class HellowServiceImp implements HellowService {
@Override
public List doHello() {
// TODO Auto-generated method stub
List<Map<String, String> > list = new ArrayList<>();
Map<String, String> map = new HashMap<>();
map.put("name", "NAME");
map.put("age", "24");
list.add(map);
return list;
}
}
dao
- 创建dao的包
- 修改配置文件
代码
- 接口 接口文件
- mapper文件 xml文件
规范:
接口与 mapper 文件名一致
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="cn.nokia.mapper.kpimapper">
<select id="selectall" resultType="java.util.HashMap">
select pm_date as datetime,enb_id as enbid,cell_id as cellid,cell_avail_rate as rate from QIYUEFANV2 where rownum < 100
</select>
<select id="selectkpi" resultType="java.util.HashMap">
select enb_id as enbid,cell_id as cellid,cell_avail_rate as rate from QIYUEFANV2 where rownum < 100
</select>
</mapper>
package cn.nokia.mapper;
import java.util.List;
import java.util.Map;
public interface kpimapper {
List<Map<String, String>> selectall();
List<Map<String, String>> selectkpi();
}
遇到问题
- 解决方法
eclipse => perferences=>development assembly =>add => java build path entries