Spring Boot

一、Spring Boot搭建环境

1.方式一:进入Spring Boot 官方网站,点击QUICK START,选择current版本。点击start.spring.io。

162741_otwI_3544275.png

162751_HW5N_3544275.png

如果是web项目可以加入web 依赖,点击Generate Project生成demo文件,直接导入就好。

2.方式二:使用IDE工具生成。这里使用idea作为演示。

File—New—Project

162832_PLNC_3544275.png

next填写Group与Artifact,next,定制依赖,选择自己需要的依赖然后Finish

这样一个基础的Spring Boot项目就搭建好了。

3.Spring Boot如此流行的一个重要原因也是它的最大优势就是极大简化了配置,将一些常用的性能稳定的工具进行进一步地封装成一个个小模块,当需要的时候直接引入依赖就足够了,比如说我想添加与Oracle数据库的连接,仅仅要做的是加入spring-boot-starter-data-jpa的依赖,与标识Oracle的依赖包ojdbc,另外在配置文件中配置一下连接的url、用户名密码就好、甚至数据源都不需要自己去装配、它默认使用tomcat的连接池。当需要自己去定制连接池的时候,直接在配置文件中加入连接池的Bean位置(全名称)就好,极大简化了spring的初始配置,非常适合一些独立运行的小项目的搭建,快速稳定。

 

二、Spring Boot 连接Oracle数据库

1.使用Spring自带的JdbcTemplate。

以查询班级信息为例。数据库中表字段:

162825_YFiC_3544275.png

2.pom.xml中加入依赖:

        <!--Oracle-->
		<dependency>
			<groupId>com.oracle</groupId>
			<artifactId>ojdbc14</artifactId>
			<version>10.2.0.4.0</version>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-jpa</artifactId>
		</dependency>

3.application.properties中加入数据库配置。(也可以用yml配置文件,不过个人不习惯)

#数据库
spring.datasource.type=org.apache.tomcat.jdbc.pool.DataSource
spring.datasource.tomcat.max-wait=10000
spring.datasource.tomcat.max-active=50
spring.datasource.tomcat.test-on-borrow=true
#前面四个配置可以不写,因为在Spring Boot 1.5.9版本中是默认使用tomcat的连接池。
spring.datasource.url=jdbc:oracle:thin:@127.0.0.1(IP地址):1521(端口号):orcl(实例名)
spring.datasource.username=username
spring.datasource.password=password

4.ClassDaoImpl中。

@Repository
public class ClassDaoImpl{
    @Autowired
    private JdbcTemplate jdbcTemplate;
    public List<Class> findAll() {
        String sql = "select * from class";
        return jdbcTemplate.query(sql, (resultSet, i) -> {
            Class classInf = new Class();
            classInf.setClassid(resultSet.getString("CLASSID"));
            classInf.setClassname(resultSet.getString("CLASSNAME"));
            classInf.setClassno(resultSet.getString("CLASSNO"));
            classInf.setGrade(resultSet.getString("GRADE"));
            classInf.setPid(resultSet.getString("PID"));
            classInf.setState(resultSet.getInt("STATE"));
            return classInf;
        });

5.ClassController中:

@RestController
public class ClassController {

    @Resource(name = "classDao")
    private ClassDao classDao;

    @RequestMapping("/test")
public List<Class> findAll() {
        return classDao.findAll();
    }
}

@RestController是Spring Boot特有的注解,被注解的类其中的方法都默认将对象以一种流的方式处理成Json串返回。

测试:1.启动Application,Application是Spring Boot启动的入口,Spring Boot 直接集成了servlet容器tomcat7、8、jetty、Undertow,默认是tomcat。不需要进行额外配置。直接启动即可。

2.若换成jetty,在pom文件的starter中,排除tomcat、增加jetty依赖即可。

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
   <exclusions>
      <exclusion>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-tomcat</artifactId>
      </exclusion>
   </exclusions>
</dependency>

增加jetty依赖:

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jetty</artifactId>
</dependency>

3.浏览器访问http://localhost:8080/test,就会返回从数据库红查找出的字符串。

三、Spring Boot添加定时任务:

1.添加配置类:

@Configuration
@EnableScheduling
public class Scheduler {
    private final Logger logger = LoggerFactory.getLogger(this.getClass());

    @Resource(name = "scheduleService")
    private ScheduleService scheduleService;

    @Scheduled(cron = "${SCHEDULEINTERVAL}")
    public void doTask() {
        logger.info("定时任务开始");
        scheduleService.doTask();
        logger.info("定时任务结束");
    }
}

@Configuration表示这是一个配置类

@EnableScheduling表示开启定时任务,

Cron表达式从配置文件中获取。为SCHEDULEINTERVAL=0 0/10 * * * ?

意为每十分钟执行一次。

 

四、Spring Boot执行存储过程。

String sql = "call TESTPROCEDURE(10)";

TESTPROCEDURE为过程名,(10)表示入参为10。
jdbcTemplate.execute(sql);

五、Spring Boot获取配置文件中的List数据

1.配置文件中:

#包名
PROCEDURE.PACKAGENAME[0]=PKG_AJJ_DATA_FMKS
PROCEDURE.PACKAGENAME[1]=PKG_AJJ_DATA_TZRY
PROCEDURE.PACKAGENAME[2]=PKG_AJJ_DATA_WXP
PROCEDURE.PACKAGENAME[3]=PKG_AJJ_DATA_YZDP
PROCEDURE.PACKAGENAME[4]=PKG_AJJ_DATA_ZZJG
#过程名
PROCEDURE.PROCEDURENAME[0]=PRC_BN_INF_APPLY
PROCEDURE.PROCEDURENAME[1]=PRC_BN_INF_APPLY_PROCESS
PROCEDURE.PROCEDURENAME[2]=PRC_BN_INF_APPLY_RESULT
PROCEDURE.PROCEDURENAME[3]=PRC_T_ZZ_ZM_INFO
PROCEDURE.PROCEDURENAME[4]=PRC_BASE_INFO
PROCEDURE.PROCEDURENAME[5]=PRC_ERROR_INFO

2.配置类:

@ConfigurationProperties(prefix = "PROCEDURE")
@Component(value = "procedureName")
public class ProcedureName {
    private List<String> PACKAGENAME = new ArrayList<>();
    private List<String> PROCEDURENAME = new ArrayList<>();

    public List<String> getPACKAGENAME() {
        return PACKAGENAME;
    }

    public void setPACKAGENAME(List<String> PACKAGENAME) {
        this.PACKAGENAME = PACKAGENAME;
    }

    public List<String> getPROCEDURENAME() {
        return PROCEDURENAME;
    }

    public void setPROCEDURENAME(List<String> PROCEDURENAME) {
        this.PROCEDURENAME = PROCEDURENAME;
    }
}

@ConfigurationProperties(prefix = "PROCEDURE")

自动将配置文件中前缀为PROCEDURE的配置信息自动映射到类中。

@Component(value = "procedureName")

让Spring自动创建,可以在其它类中装配。

转载于:https://my.oschina.net/u/3544275/blog/1583549

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值