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

SpringMvc+Spring+MyBatis+Maven+Ajax+Json注解开发 利用Maven的依赖导入不使用架包模式 (实操十二)

SpringMvc+Spring+MyBatis+Maven+Ajax+Json注解开发 利用Maven的依赖导入不使用架包模式 (实操十一)_星辰镜的博客-CSDN博客

上面的博客是环境配置和Mysql的操作

本文章的目标 完成对数据库中表的一条记录进行修改

MySql的Sql语句:

UPDATE `demossmtest`.`orders` 
SET 
`name` = '电脑AS', 
`foondname` = '华为OS', 
`ordertime` = '2022.6.9',
 `count` = 3456, 
`price` = 3452.09,
 `amount` = 1234.09 
WHERE 
`id` = 6

修改的思想分析总结::

  1. 首先用户要将你要修改的是哪条记录的参数发到服务器中

  2. 服务器利用SSM三层原理最终将其告诉数据库中

  3. ​我查到的每一条记录 的存放方式是 Map<String, Object> ​

  4. 返回的类型为 Map<String, Object> 方法名称(转入的参数) ​ Map<String, Object> getInfoById(int id);

  5. 将修改的信息经过层层返回最终到控制层

  6. ​将修改信息如何展示在页面上这里需要你的前端基础 ​ Html css javascript jquery Ajax Json

  7. 将浏览器修改后的信息返回到服务器 中到数据库中完成数据的修改

  8. ​将修改的信息利用Map封装起来 ​ 所以 返回的类型为 int方法名称(转入的参数) ​ int updateInfo(Map<String, Object> map); ​

  9. 思考你要修改的是一条记录 而一条记录利用的是 Map<String, Object> 存放 返回一条记录的值为 int 类型

  10. 所以接口定义下面方案 ​ int updateInfo(Map<String, Object> map);


修改页面的效果前后展示:

471551dc3f3d4e6b9c60b61e4003d054.png

1

 

93c02147715f40e69e26b253312af0c4.png

2

 

3d99e69a00ee494eb82d8d8bc44e9932.png

3

 

159da2f9959b46278d09d63ffca6ede0.png

4

 

3b685e5ec1424654853958fd48d3879c.png

5


代码操作一:显示修改信息的数据展示在页面中

9e04a5bbbcf84dfd9317aee9ca0c0f4c.png

1

//    定义方法修改页面 转入参数id
        function update(id) {
            confirm("开始修改页面信息")
            alert("请用户开始操作页面即将跳到修改的数据页面")
            location.href = "update1.do?id=" + id;

        }
c2df9cc51d9944d69669b328a5236b29.png

2

 

 <script src="js/jquery-3.2.1.min.js"></script>
    <script>
        $(function () {
            $.ajax({
                url: "Update2.do",
                type: "GET",
                data: "",
                //将所有的修改的值展示到表格中
                success: function (json) {
                    $("input[name='name']").val(json.name)
                    $("input[name='foondname']").val(json.foondname)
                    $("input[name='price']").val(json.price)
                    $("input[name='count']").val(json.count)
                    $("input[name='ordertime']").val(json.ordertime)
                    $("input[name='amount']").val(json.amount)

                },
                error: function () {
                    alert("连接数据库失败")
                },
                dataType: "json"
            })
        })
    </script>
1212db9454b44076b43361cc5294f7fa.png

3

 

88b7aeb899fe49489d4d437aff91fc72.png

4

 

4e4e89816aa946a49b986e2fc356fc04.png

5

 

118e785528bd495ca9707b1f838d8cb2.png

6

 代码操作二修改信息返回到数据库中完成真正的修改

<div align="center">
    <h1>淘宝页面修改页面的内容管理</h1>
    <form action="update3.do" method="get">
        <table>
            <tr>
                <td>用户名:</td>
                <td><input type="text" name="name"></td>
            </tr>
            <tr>
                <td>商品名称:</td>
                <td><input type="text" name="foondname"></td>
            </tr>
            <tr>
                <td>商品单价:</td>
                <td><input type="text" name="price"></td>
            </tr>
            <tr>
                <td>商品数量:</td>
                <td><input type="number" name="count"></td>
            </tr>

            <tr>
                <td>订单更新时间:</td>
                <td><input type="text" name="ordertime"></td>
            </tr>

            <tr>
                <td>金额</td>
                <td><input type="text" name="amount"></td>
            </tr>
            <tr>
                <th colspan="2"><input type="submit" value="完成修改信息"></th>
            </tr>
        </table>

    </form>
</div>
@RequestMapping("/update3.do")
    public String update3(
                          @RequestParam String name,
                          @RequestParam String foondname,
                          @RequestParam String ordertime,
                          @RequestParam int count,
                          @RequestParam double price,
                          @RequestParam double amount,
                          HttpSession  session) {
        Map<String, Object> map = new HashMap<>();
        int id = (int) session.getAttribute("id");
        map.put("id",id);
        map.put("name",name);
        map.put("foondname",foondname);
        map.put("ordertime",ordertime);
        map.put("count",count);
        map.put("price", price);
        map.put("amount",amount);
        int i = service.update3(map);
        return "Service.html";
    }
package Com.Orders.Service;

import java.util.List;
import java.util.Map;

/**
 * 业务逻辑层的接口
 */

public interface IOrderService {
    List<Map<String, String>> getList();


    Map<String, Object> update2(int id);

    int update3(Map<String, Object> map);
}
@Override
    public int update3(Map<String, Object> map) {
        return dao.update3(map);
    }
6ce09ad144194fdda94f7191345a6590.png

7

 

@Update("UPDATE `demossmtest`.`orders` SET  name = #{name}, foondname = #{foondname}, ordertime = #{ordertime}, count = #{count}, price = #{price}, amount =#{amount} where id = #{id}")
    int update3(Map<String, Object> map)

总结核心:两条Sql语句的实现:

 

118e785528bd495ca9707b1f838d8cb2.png

@Update("UPDATE `demossmtest`.`orders` SET  name = #{name}, foondname = #{foondname}, ordertime = #{ordertime}, count = #{count}, price = #{price}, amount =#{amount} where id = #{id}")
    int update3(Map<String, Object> map);
  1. 首先用户要将你要修改的是哪条记录的参数发到服务器中

  2. 服务器利用SSM三层原理最终将其告诉数据库中

  3. ​我查到的每一条记录 的存放方式是 Map<String, Object> ​

  4. 返回的类型为 Map<String, Object> 方法名称(转入的参数) ​ Map<String, Object> getInfoById(int id);

  5. 将修改的信息经过层层返回最终到控制层


  1. ​将修改信息如何展示在页面上这里需要你的前端基础 ​ Html css javascript jquery Ajax Json

  2. 将浏览器修改后的信息返回到服务器 中到数据库中完成数据的修改

  3. ​将修改的信息利用Map封装起来 ​ 所以 返回的类型为 int方法名称(转入的参数) ​ int updateInfo(Map<String, Object> map); ​

  4. 思考你要修改的是一条记录 而一条记录利用的是 Map<String, Object> 存放 返回一条记录的值为 int 类型

  5. 所以接口定义下面方案 ​ int updateInfo(Map<String, Object> map)

 

 

 

 

 

相关文章:

  • [Go WebSocket] 多房间的聊天室(三)自动清理无人房间
  • linux进程管理-进程
  • 【图像透视】基于matlab图像逆透视映射【含Matlab源码 2139期】
  • 【Java】逻辑控制
  • Qt下生成pdb文件,并在exe崩溃时生成dmp文件,且由dmp查询崩溃原因
  • 蜂鸣器、风扇、震动马达
  • 【VRP问题】基于帝国企鹅优化算法求解冷链配送物流车辆调度优化研究
  • 3) 时频分析与傅立叶变换
  • stm32f4xx-I2C
  • 有了这个 Python 库,以后再也不用写正则表达式了
  • 学习python很无聊?看看这几个有意思的代码,拿去整蛊一下好朋友~ 适当娱乐哈
  • 【老生谈算法】matlab实现滤波器设计源码——滤波器设计
  • 后端研发工程师面经——手撕设计模式
  • 1679. K 和数对的最大数目-自定义哈希表解决
  • 【Objective-C内存管理之引用计数】
  • 「前端」从UglifyJSPlugin强制开启css压缩探究webpack插件运行机制
  •  D - 粉碎叛乱F - 其他起义
  • eclipse的离线汉化
  • emacs初体验
  • es6要点
  • gulp 教程
  • Java IO学习笔记一
  • nginx 配置多 域名 + 多 https
  • opencv python Meanshift 和 Camshift
  • SpiderData 2019年2月25日 DApp数据排行榜
  • vue 个人积累(使用工具,组件)
  • Vue 2.3、2.4 知识点小结
  • vue自定义指令实现v-tap插件
  • 前端js -- this指向总结。
  • 入门到放弃node系列之Hello Word篇
  • 手机app有了短信验证码还有没必要有图片验证码?
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • kubernetes资源对象--ingress
  • 第二十章:异步和文件I/O.(二十三)
  • ​DB-Engines 12月数据库排名: PostgreSQL有望获得「2020年度数据库」荣誉?
  • ###STL(标准模板库)
  • (env: Windows,mp,1.06.2308310; lib: 3.2.4) uniapp微信小程序
  • (二)丶RabbitMQ的六大核心
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (学习日记)2024.01.09
  • (转)EXC_BREAKPOINT僵尸错误
  • (转)真正的中国天气api接口xml,json(求加精) ...
  • ..thread“main“ com.fasterxml.jackson.databind.JsonMappingException: Jackson version is too old 2.3.1
  • ./和../以及/和~之间的区别
  • .bat批处理(二):%0 %1——给批处理脚本传递参数
  • .Net MVC + EF搭建学生管理系统
  • .NET MVC之AOP
  • .net 无限分类
  • .netcore 如何获取系统中所有session_ASP.NET Core如何解决分布式Session一致性问题
  • .NET中的Exception处理(C#)
  • /bin/rm: 参数列表过长"的解决办法
  • /run/containerd/containerd.sock connect: connection refused
  • [.net 面向对象程序设计进阶] (19) 异步(Asynchronous) 使用异步创建快速响应和可伸缩性的应用程序...
  • [C++]类和对象【上篇】
  • [CISCN 2019华东南]Web11