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

视频素材网站建设网站制作 中企动力公司

视频素材网站建设,网站制作 中企动力公司,宝塔面板建设二级域名网站访问不了,怎么样开网店卖东西文章目录一、实现步骤1、准备数据库表2、在IDEA中创建一个模块#xff0c;并引入依赖3、基于三层架构实现4、编写pojo5、编写mapper接口6、编写mapper配置文件7、编写service接口和service接口的实现类8、编写jdbc.properties配置文件9、编写mybatis-config.xml配置文件10、编… 文章目录一、实现步骤1、准备数据库表2、在IDEA中创建一个模块并引入依赖3、基于三层架构实现4、编写pojo5、编写mapper接口6、编写mapper配置文件7、编写service接口和service接口的实现类8、编写jdbc.properties配置文件9、编写mybatis-config.xml配置文件10、编写spring.xml配置文件【配置地狱】11、编写测试程序添加事务进行测试一、实现步骤 1、准备数据库表 t_act银行账户 2、在IDEA中创建一个模块并引入依赖 spring-contextspring-jdbcmysql驱动mybatismybatis-spring mybatis提供的与spring框架集成的依赖德鲁伊连接池junit 为什么有了mybatis驱动还需要jdbc 因为事务tx在jdbc包里 dependenciesdependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.11/versionscopetest/scope/dependencydependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion5.1.32/version/dependencydependencygroupIdorg.springframework/groupIdartifactIdspring-context/artifactIdversion5.2.5.RELEASE/version/dependencydependencygroupIdorg.springframework/groupIdartifactIdspring-jdbc/artifactIdversion5.2.5.RELEASE/version/dependencydependencygroupIdorg.mybatis/groupIdartifactIdmybatis/artifactIdversion3.5.6/version/dependencydependencygroupIdorg.mybatis/groupIdartifactIdmybatis-spring/artifactIdversion1.3.1/version/dependencydependencygroupIdcom.alibaba/groupIdartifactIddruid/artifactIdversion1.0.20/version/dependency/dependencies3、基于三层架构实现 创建所有的包 com.powernode.bank.pojo com.powernode.bank.mapper com.powernode.bank.service com.powernode.bank.service.impl 4、编写pojo Account:属性私有化提供公开的setter getter toString public class Account {private String actno;private double balance;public Account(String actno, double balance) {this.actno actno;this.balance balance;}public Account() {}public String getActno() {return actno;}public void setActno(String actno) {this.actno actno;}public double getBalance() {return balance;}public void setBalance(double balance) {this.balance balance;}Overridepublic String toString() {return Account{ actno actno \ , balance balance };} }5、编写mapper接口 AccountMapper接口定义方法 public interface AccountMapper {//该接口的实现类不需要写是mybatis通过动态代理机制生成的实现类//查询所有的账户ListAccount seleteAllAccount();//根据actno查询指定账户Account selectByActno(String actno);//增加账户int insertAccount(Account account);//删除账户int deleteByActno(String actno);//修改账户int update(Account account); }6、编写mapper配置文件 在配置文件中配置命名空间以及每一个方法对应的SQL mapper namespace“com.powernode.bank.mapper.AccountMapper” ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapperPUBLIC -//mybatis.org//DTD Mapper 3.0//ENhttps://mybatis.org/dtd/mybatis-3-mapper.dtdmapper namespacecom.powernode.bank.mapper.AccountMapperselect idselectAllAccount resultTypeaccountselect * from t_act/selectselect idselectByActno resultTypeaccountselect * from t_actwhere actno#{actno};/selectinsert idinsertAccountinsert into t_actvalues(#{actno},#{balance})/insertdelete iddeleteByActnodelete from t_actwhere actno#{actno}/deleteupdate idupdateupdate t_actset balance#{balance} where actno#{actno}/update/mapper7、编写service接口和service接口的实现类 AccountService public interface AccountService {//业务接口int save(Account account);int deleteByActno(String actno);int modify(Account account);Account getByActno(String actno);ListAccount getAll();void transfer(String fromActno,String toActno,double money); }AccountServiceImpl 注意一定要进行AccountServiceImpl Bean实例化Service(“accountService”) 以及一定要注入AccountMapper Bean注入 Autowired Service(accountService) public class AccountServiceImpl implements AccountService {Autowiredprivate AccountMapper mapper;Overridepublic int save(Account account) {int i mapper.insertAccount(account);return i;}Overridepublic int deleteByActno(String actno) {int i mapper.deleteByActno(actno);return i;}Overridepublic int modify(Account account) {mapper.update(account);return 0;}Overridepublic Account getByActno(String actno) {return mapper.selectByActno(actno);}Overridepublic ListAccount getAll() {return mapper.seleteAllAccount();}Overridepublic void transfer(String fromActno, String toActno, double money) {Account fromAct mapper.selectByActno(fromActno);Account toAct mapper.selectByActno(toActno);if(fromAct.getBalance()money){throw new RuntimeException(余额不足);}fromAct.setBalance(fromAct.getBalance()-money);toAct.setBalance(toAct.getBalance()money);int count mapper.update(fromAct);count mapper.update(toAct);if(count2){System.out.println(转账成功);}else{throw new RuntimeException(转账失败);}} }8、编写jdbc.properties配置文件 jdbc.drivercom.mysql.jdbc.Driver jdbc.urljdbc:mysql://localhost:3306/dududu?useSSLfalse jdbc.usernameroot jdbc.password1234569、编写mybatis-config.xml配置文件 这个文件可以没有大部分的配置可以转移到spring配置文件中 如果遇到mybatis相关的系统级配置还是需要这个文件?xml version1.0 encodingUTF-8 ? !DOCTYPE configuration PUBLIC -//mybatis.org//DTD Config 3.0//ENhttp://mybatis.org/dtd/mybatis-3-config.dtd configuration!--设置日志输出语句,显示相应操作的sql语名--settingssetting namelogImpl valueSTDOUT_LOGGING//settings /configuration10、编写spring.xml配置文件【配置地狱】 1、组件扫描 2、引入外部的属性文件 3、数据源 4、SqlSessionFactoryBean配置 注入mybatis核心配置文件 指定别名包 注入数据源 5、Mapper扫描配置器主要扫描mapper接口生成代理类 扫描指定的包 6、事务管理器 DataSourceTransactionManager 注入数据源 7、启用事务注解【启用之后在业务实现类当中添加注解Transactional 事务才会起作用】 注入事务管理器 ?xml version1.0 encodingUTF-8? beans xmlnshttp://www.springframework.org/schema/beansxmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexmlns:contexthttp://www.springframework.org/schema/context xmlns:txhttp://www.springframework.org/schema/txxsi:schemaLocationhttp://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 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd!--组件扫描--!--context:component-scan base-packagecom.powernode.bank/--!--在spring的核心配置文件中引入其他的子spring配置文件--context:component-scan base-packagecom.powernode.bank/context:component-scancontext:property-placeholder locationjdbc.properties/context:property-placeholder!--数据源--bean iddataSource classcom.alibaba.druid.pool.DruidDataSourceproperty namedriverClassName value${jdbc.driver}/property nameurl value${jdbc.url}/property nameusername value${jdbc.username}/property namepassword value${jdbc.password}//bean!--配置SqlSessionFactoryBean--bean classorg.mybatis.spring.SqlSessionFactoryBean!--注入数据源--property namedataSource refdataSource/!--指定mybatis核心配置文件--property nameconfigLocation valuemybatis-config.xml/!--指定别名--property nametypeAliasesPackage valuecom.powernode.bank.pojo//bean!--Mapper扫描配置器主要扫描Mapper接口生成代理类--bean classorg.mybatis.spring.mapper.MapperScannerConfigurerproperty namebasePackage valuecom.powernode.bank.mapper//bean!--事务管理器--bean idtxManager classorg.springframework.jdbc.datasource.DataSourceTransactionManagerproperty namedataSource refdataSource//bean!--启用事务注解--tx:annotation-driven transaction-managertxManager//beans11、编写测试程序添加事务进行测试 Testpublic void testSM(){ApplicationContext ac new ClassPathXmlApplicationContext(spring.xml);AccountService accountService ac.getBean(accountService,AccountService.class);//accountService.transfer(act_001,act_002,2000);accountService.save(new Account(act_005,20));ListAccount AccountList accountService.getAll();AccountList.forEach(list-{System.out.println(账号为list.getActno(),账户余额为list.getBalance());});}
http://www.hkea.cn/news/14550405/

相关文章:

  • 科技期刊网站建设dede电影网站模板
  • 雄安网站建设推广烟台网站排名优化报价
  • 国际化网站济南网站建设艮安
  • 阿里云快速做网站北京鲜花的网站建设
  • 辽宁省建设厅证书查询网站网站首页排名
  • 淄博网站建设公司有几家文网文许可证
  • 为女朋友做网站wordpress flash加载
  • 网站更换服务器企业设计网站推荐
  • 网站建设在哪里做比较好免费ppt模板下载熊猫
  • 网站开发搜索功能怎么实现做任务给佣金的网站有哪些
  • 做商城购物网站公司网站维护都需要怎么做
  • iis做外网站点wordpress缩略图比例
  • 网站制作好学吗贸易网站建设方案
  • 网站提权网页设计心得体会600字
  • 营销网站建设都是专业技术人员凡客诚品鞋子质量怎么样
  • 云南建设厅网站工程师怎样去网上接网站建设和小程序的单
  • 公司的网站是怎么建立网站建设要做哪些工作室
  • 生物技术网站开发024 网站推广
  • 电子商务智能建站网页制作工具中可进行网页内容定位
  • 一般网站的优缺点如何做网站的登录注册
  • 建设银行湖北省分行 网站何为响应式网站
  • 网站流量少怎么做wordpress接入信用卡付款
  • 怎么建设幸运28网站电商网站建设系统
  • 巫山做网站哪家强济南媒体邀约
  • 怎么选择镇江网站建设佛山市公司网站建设哪家好
  • 不花钱怎么做网站运营济南品牌网站建设价格低
  • 巴州移动网站建设中国邮政做特产的网站
  • 怎么做试玩平台推广网站企业网站设计制作服务
  • eclipse网站开发实例无锡制作网站公司哪家好
  • 承德专业做网站的公司微信分享 淘宝网站 怎么做