项目开发框架-SSM

1.Spring
无需多言,作为开源届数一数二的典例,项目开发中无处不在;核心IOC容器,用来装载bean(java中的类)-用Spring的IOC容器来管理Bean的生命周期,有了这样一种机制,我们就可以不用在代码中去重复的做new操作。aop,面向切面编程,spring中最主要的是用于事务方面的使用。

作者:glmapper
链接:https://juejin.im/post/59f3ef5c51882534aa0691b2
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

2.Spring MVC
作用于web层,相当于controller,与struts中的action一样,都是用来处理用户请求的。同时,相比于struts2来说,更加细粒度,它是基于方法层面的,而struts是基于类层面的。这里写图片描述
3.MyBatis
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。[来自:www.mybatis.org/mybatis-3/z…]
他人总结

Hibernate功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快,非常爽。
Hibernate的缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。
MYBATIS入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。
MYBATIS的缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。4.SSM框架整合
本项目将以购物为背景,主要包括商品信息及库存【因为想顺便学习一下事务的处理】、订单信息。下面将从数据库创建、项目结构说明、配置文件、业务代码等方面进行一步步说明。4.1 数据库创建
1.商品表CREATE TABLE goods (
goods_id bigint(20) NOT NULL AUTO_INCREMENT COMMENT ‘商品ID’,
goodsname varchar(100) NOT NULL COMMENT ‘商品名称’,
number int(11) NOT NULL COMMENT ‘商品库存’,
PRIMARY KEY (goods_id)
) ENGINE=InnoDB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COMMENT=’商品表’复制代码初始化表数据INSERT INTO goods (goods_id, goodsname, number)
VALUES (1001, ‘SN卫衣’, 15)复制代码2.订单表CREATE TABLE orderinfo (
order_id varchar(20) NOT NULL COMMENT ‘订单编号’,
goods_id bigint(18) NOT NULL COMMENT ‘商品ID’,
user_id bigint(10) NOT NULL COMMENT ‘用户ID’,
order_time timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT ‘下单时间’ ,
PRIMARY KEY (order_id),
INDEX idx_order_id (order_id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=’订单表’复制代码OK,至此表结构及初始化数据构建完成,下面说下基于Mavan的项目结构。项目结构说明
因为项目是使用maven来管理jar包的,先来贴一下,pom.xml的配置
pom.xml为了避免学习小伙伴崇尚拿来主义【也就是去除了xmlns之类的东西】,这里只放项目依赖的jar包的dependencies;本案例将本着“需则用”的原则,避免在网上看到的各种乱七八糟的依赖都丢进来的情况,造成资源浪费和干扰阅读。
<依赖项> <! - 单元测试 - > <依赖> < groupId > junit < artifactId > junit < version > 4.11 <! - 1.日志slf4j - > ch.qos.logback logback-classic 1.1.1 <! - 2.数据库连接驱动 - >
mysql
mysql-connector-java
5.1.37
runtime



c3p0
c3p0
0.9.1.2

  <!-- 3.MyBatis 以及 spring-mybatis -->
  <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.3.0</version>
  </dependency>
  <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.2.3</version>
  </dependency>

  <!-- 4.Servlet 相关依赖 -->
  <dependency>
      <groupId>taglibs</groupId>
      <artifactId>standard</artifactId>
      <version>1.1.2</version>
  </dependency>
  <dependency>
      <groupId>jstl</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
  </dependency>
  <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.5.4</version>
  </dependency>
  <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>3.1.0</version>
  </dependency>

  <!-- 5.Spring -->

  <!-- 5.1 Spring核心 :core bean context -->
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-core</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-beans</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <!-- 5.2 Spring jdbc依赖,事务依赖 -->
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <!-- 5.3 Spring web依赖>
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>
  <!-- 5.4 Spring test -->
  <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-test</artifactId>
      <version>4.1.7.RELEASE</version>
  </dependency>

  <!-- 6.redis客户端:Jedis【不使用的话可以直接去除】 -->
  <dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
      <version>2.7.3</version>
  </dependency>
  <dependency>
      <groupId>com.dyuproject.protostuff</groupId>
      <artifactId>protostuff-core</artifactId>
      <version>1.0.8</version>
  </dependency>
  <dependency>
      <groupId>com.dyuproject.protostuff</groupId>
      <artifactId>protostuff-runtime</artifactId>
      <version>1.0.8</version>
  </dependency>

  <!-- 7.工具类 -->
  <dependency>
      <groupId>commons-collections</groupId>
      <artifactId>commons-collections</artifactId>
      <version>3.2</version>
  </dependency>

复制代码*项目结构图
这里写图片描述src/test/java:用于junit的测试类
src/main/java: dao:数据库处理 service:业务处理 enums:项目枚举 mapper:dao中方法对应mybatis映射文件,Sql就在这里面 web:控制器,controller entity:项目中的实体类,如:商品类和订单类
配置文件

jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://serverName:port/dbname?useUnicode=true&characterEncoding=utf8
jdbc.username=[填写自己的数据库用户名]
jdbc.password=[填写自己的数据库登录密码]复制代码
logback.xml这里直接用的是控制台输出,如果是生产环境,可以根据具体的需求进行配置。

猜你喜欢

转载自blog.csdn.net/qq_41608180/article/details/82215488