当前位置: 首页 > news >正文

服务器搭建网站云网站功能

服务器搭建网站,云网站功能,京东的电子商务网站建设,中国交通建设网站声明式事务 从之前的事务控制的代码中可以看出,是有规律可循,代码的结构基本是确定的,所以框架就可以将固定模式的代码抽取出来,进行相关的封装。 封装起来后,我们只需要在配置文件中进行简单的配置即可完成操作。 …

声明式事务

从之前的事务控制的代码中可以看出,是有规律可循,代码的结构基本是确定的,所以框架就可以将固定模式的代码抽取出来,进行相关的封装。

封装起来后,我们只需要在配置文件中进行简单的配置即可完成操作。

  • 好处1:提高开发效率
  • 好处2:消除了冗余的代码
  • 好处3:框架会综合考虑相关领域中在实际开发环境下有可能遇到的各种问题,进行了健壮性、性 能等各个方面的优化

所以,我们可以总结下面两个概念:

  • 编程式:自己写代码实现功能
  • 声明式:通过配置让框架实现功能

基于注解的声明式事务

添加驱动依赖

 <dependencies><!-- 基于Maven依赖传递性,导入spring-context依赖即可导入当前所需所有jar包 --><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.3.1</version></dependency><!-- Spring 持久化层支持jar包 --><!-- Spring 在执行持久化层操作、与持久化层技术进行整合过程中,需要使用orm、jdbc、tx三个jar包 --><!-- 导入 orm 包就可以通过 Maven 的依赖传递性把其他两个也导入 --><dependency><groupId>org.springframework</groupId><artifactId>spring-orm</artifactId><version>5.3.1</version></dependency><!-- Spring 测试相关 --><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.3.1</version></dependency><!-- junit测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- MySQL驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.31</version></dependency><!-- 数据源 --><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.0.31</version></dependency><!--       添加lombok驱动--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.16</version></dependency></dependencies>

创建jdbc.properties

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm?serverTime=UTC
jdbc.username=root
jdbc.password=root

配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd"><!--    引入jdbc.properties--><context:property-placeholder location="classpath:jdbc.properties"></context:property-placeholder><!--配置德鲁伊--><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"><property name="driverClassName" value="${jdbc.driver}"></property><property name="url" value="${jdbc.url}"></property><property name="username" value="${jdbc.username}"></property><property name="password" value="${jdbc.password}"></property></bean><bean class="org.springframework.jdbc.core.JdbcTemplate"><property name="dataSource" ref="dataSource"></property></bean>
</beans>

创建数据库表

--Table structure for t_book
-- ----------------------------
DROP TABLE IF EXISTS `t_book`;
CREATE TABLE `t_book`  (`book_id` int NOT NULL AUTO_INCREMENT COMMENT '主键',`book_name` varchar(20) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci NULL DEFAULT NULL COMMENT '图书名称',`price` int NULL DEFAULT NULL COMMENT '价格',`stock` int UNSIGNED NULL DEFAULT NULL COMMENT '库存(无符号)',PRIMARY KEY (`book_id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8mb3 COLLATE = utf8mb3_general_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of t_book
-- ----------------------------
INSERT INTO `t_book` VALUES (1, '斗破苍\r\n穹', 80, 98);
INSERT INTO `t_book` VALUES (2, '斗罗大陆', 50, 99);SET FOREIGN_KEY_CHECKS = 1;
-- Table structure for t_user
-- ----------------------------
DROP TABLE IF EXISTS `t_user`;
CREATE TABLE `t_user`  (`user_id` int NOT NULL AUTO_INCREMENT COMMENT '主键',`username` varchar(20) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci NULL DEFAULT NULL COMMENT '用户名',`balance` int UNSIGNED NULL DEFAULT NULL COMMENT '余额(无符号)',PRIMARY KEY (`user_id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8mb3 COLLATE = utf8mb3_general_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of t_user
-- ----------------------------
INSERT INTO `t_user` VALUES (1, 'admin', 20);
INSERT INTO `t_user` VALUES (2, '二哈', 9950);SET FOREIGN_KEY_CHECKS = 1;

创建测试代码

BookController

package com.hyh.spring.controller;import com.hyh.spring.service.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;/*** @version 1.0* @BelongsProject:IntelliJ IDEA* @BelongsPackage:com.hyh.spring.controller* @Author:hyhWTX* @ClassName:BookController* @CreateTime:2022年-12月-31日 21:49* @Description: TODO (一句话描述以下该类的功能)*/
@Controller
public class BookController {@Autowiredprivate BookService bookService;public  void  buyBook(Integer userId,Integer bookId  ){bookService.buyBook(userId,bookId);}
}

BookDao

package com.hyh.spring.dao;/*** @version 1.0* @BelongsProject:IntelliJ IDEA* @BelongsPackage:com.hyh.spring.dao* @Author:hyhWTX* @ClassName:BookDao* @CreateTime:2022年-12月-31日 21:50* @Description: TODO (一句话描述以下该类的功能)*/
public interface BookDao {/*** @Description:根据图书ID查询图书价格* @param bookId* @return Integer*/Integer getPriceByBookId(Integer bookId);/*** @Description:更新图书的库存* @param bookId*/void updateStock(Integer bookId);/*** @Description:更新用户的余额* @param userId* @param price*/void updateBalance(Integer userId, Integer price);
}

BookDaoImpl

package com.hyh.spring.dao.impl;import com.hyh.spring.dao.BookDao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;/*** @version 1.0* @BelongsProject:IntelliJ IDEA* @BelongsPackage:com.hyh.spring.dao.impl* @Author:hyhWTX* @ClassName:BookDaoImpl* @CreateTime:2022年-12月-31日 21:50* @Description: TODO (一句话描述以下该类的功能)*/
@Repository
public class BookDaoImpl implements BookDao {@Autowiredprivate JdbcTemplate jdbcTemplate;@Overridepublic Integer getPriceByBookId(Integer bookId) {String sql ="select price from t_book where book_id = ?";return jdbcTemplate.queryForObject(sql,Integer.class,bookId);}@Overridepublic void updateStock(Integer bookId) {String sql = "update t_book set stock = stock-1 where book_id = ?";jdbcTemplate.update(sql,bookId);}@Overridepublic void updateBalance(Integer userId, Integer price) {String sql = "update t_user set balance  = balance -? where user_id = ?";jdbcTemplate.update(sql,price,userId);}
}

User

package com.hyh.spring.model;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;/*** @version 1.0* @BelongsProject:IntelliJ IDEA* @BelongsPackage:com.hyh.spring.model* @Author:hyhWTX* @ClassName:User* @CreateTime:2022年-12月-31日 18:21* @Description: TODO (一句话描述以下该类的功能)*/
//@Data:注解是lombok中的注解,用于针对属性自动生成set和get方法、无参数的构造方法、toString、equals、hashcode
@Data
//生成带有所有参数的构造方法
@AllArgsConstructor
//生成无参数的构造方法
@NoArgsConstructor
public class User {//用户idprivate Integer id;//用户姓名private String username;//用户密码private String password;//用户年龄private Integer age;//用户性别private String gender;//用户emailprivate String email;
}

BookService

package com.hyh.spring.service;/*** @version 1.0* @BelongsProject:IntelliJ IDEA* @BelongsPackage:com.hyh.spring.service* @Author:hyhWTX* @ClassName:BookService* @CreateTime:2022年-12月-31日 21:49* @Description: TODO (一句话描述以下该类的功能)*/
public interface BookService {/*** @Description: 买书* @param userId* @param bookId*/void buyBook(Integer userId, Integer bookId);
}

BookSerViceImpl

package com.hyh.spring.service.impl;import com.hyh.spring.dao.BookDao;
import com.hyh.spring.service.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;import java.util.concurrent.TimeUnit;/*** @version 1.0* @BelongsProject:IntelliJ IDEA* @BelongsPackage:com.hyh.spring.service.impl* @Author:hyhWTX* @ClassName:BookSerViceImpl* @CreateTime:2022年-12月-31日 21:49* @Description: TODO (一句话描述以下该类的功能)*/
@Service
@Transactionalpublic class BookSerViceImpl implements BookService {@Autowiredprivate BookDao bookDao;@Overridepublic void buyBook(Integer userId, Integer bookId) {//查询图书的价格Integer price = bookDao.getPriceByBookId(bookId);//更新图书的库存,假设每次只买一本书bookDao.updateStock(bookId);//更新用户的余额bookDao.updateBalance(userId,price);}
}
http://www.yayakq.cn/news/404985/

相关文章:

  • 郑州建网站哪个公司好wordpress 301
  • 你们需要网站建设那个网站可教做课件好
  • 公司网站设计公司网站建设和邮箱的关联
  • tag 网站托管公司企业服务公司排名
  • 宜宾市网站建设做质粒图谱的网站
  • 内容型网站有哪些彩票网站开发 合法
  • 比较好的外贸网站织梦cms零基础做网站
  • 呼伦贝尔做网站学校网站建设的建议
  • 下载建设网站阿里云虚拟主机wordpress
  • 一个网站可以有几个域名四川专业网站建设
  • 太原市0元网站建设百度推广助手app下载
  • 域名备案网站名称绵阳欣城建设
  • 赤峰做网站的公司服务商平台登录入口
  • 河南电商网站开发wordpress商业化插件
  • 珠海网站优化盐城做网站
  • 网站开发课题开发背景恩施做网站公司
  • 如何做网站网页流程国外网站建设发展现状
  • 温州市网站建设公司网络营销是啥意思
  • 如何免费建购物网站wordpress dashicons
  • 招聘网站开发时间网站建设方案产业
  • 东莞网站建设的方案博采网络
  • 外贸英语 网站网站建设中 倒计时
  • 手机网页设计制作网站wordpress 兔
  • 常州网站价格公司网站建设一条龙
  • 东莞做网站首选企业铭什么网站做简历
  • 手机怎么打开自己做的网站wordpress 云服务器
  • 网站优化目标网站图片3d显示效果
  • 护肤品网站建设环境分析深圳公司排行榜
  • 个人公司网站模板网站开发江西
  • 制作商城网站模板创意极简logo