欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

项目开发框架-SSM

程序员文章站 2022-03-27 09:44:52
...

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是基于类层面的。项目开发框架-SSM
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>

复制代码*项目结构图
项目开发框架-SSMsrc/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这里直接用的是控制台输出,如果是生产环境,可以根据具体的需求进行配置。

相关标签: ssm