Spring mvc是如何实现与数据库的前后端的连接操作的?


Posted in Java/Android onJune 30, 2021

Spring mvc与数据库的前后端的连接

springboot是基于maven的基础上管理jar包的,只不过是使用springboot下载jar包只需选中即可,就会自动的在pom.xml文件中配置组件

在pom文件中的jar包的快捷键:右键--->generate---->depency---->搜索jar包

如果在前后端传参数是输入了参数却返回null , 则说明属性的名字(id,name等)写错了

 启动类:注意 ,启动类必须在启动类中进行执行.必能在idea的上面进行启动,否则会启动其他的启动类导致报错

package cn.tedu;
 
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//启动类
@SpringBootApplication
public class RunApp {
    public static void main(String[] args) {
        SpringApplication.run(RunApp.class);
    }
}

创建car类(相当于model层)

注意:这里使用的是构造方法 主要的作用是方便new

package cn.tedu.pojo;
//Model用来封装数据
public class Car {
    private int id;
    private String name;
    private double price;
    //Constructor构造方法,用来方便的new
    public Car(){}
    public Car(int id, String name, double price) {
        this.id = id;
        this.name = name;
        this.price = price;
    }
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public double getPrice() {
        return price;
    }
    public void setPrice(double price) {
        this.price = price;
    }
}

使用三种方式  < 对象 > 进行传参数;注意:使用此类型进行设置值必须有构造方法

对象的地址值:http://localhost:8080/car/get

package cn.tedu.controller;
//MVC里的C层,用来接受请求和做出响应(springmvc)
 
import cn.tedu.pojo.Car;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
@RestController//接受请求,并把json数据返回
@RequestMapping("car")  //规定了url地址的写法
public class CarController {
//方式一值会在网页中出现
    @RequestMapping("get")
    public Car get(){
        Car c = new Car(10,"BMW",19.9);   //出发钩造函数,此处触发的是含参构造;
        return c ;
    }
//方式二值会在网页中出现
 @RequestMapping("save3")
    public Car save() {
        car.setAge(213);
        car.setSex("男");
        car.setId(32);
         car.setPrice(32);
        return car;
    }
方式三这种方式的值会在idea中打印不会再网页中出现
@RequestMapping("save3")
    public Car save() {
        car.setAge(213);
        car.setSex("男");
        car.setId(32);
         car.setPrice(32);
        System.out.println(car);
}

使用return(值会网页中出现)的方式

package cn.tedu.controller;
 
import cn.tedu.pojo.Car;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import javax.naming.Name;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
 
//这是一个c层用来接收请求和做出响应
@RestController
//@RequestMapping("car")//规定了url的写法此时的值可以任意写
public class Controller {
 
 
   @RequestMapping("replace")
    public String replace(){
       // System.out.println(id+name+age);
 
        return "hkjds";
    }
//方式二值会在网页中出现
 @RequestMapping("save3")
    public Car save() {
        car.setAge(213);
        car.setSex("男");
        car.setId(32);
         car.setPrice(32);
        return car;
    }
 
 
}
 
}

使用普通的get的方法进行上传

package cn.tedu.controller;
 
import cn.tedu.pojo.Car;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import javax.naming.Name;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
 
//这是一个c层用来接收请求和做出响应
@RestController
//@RequestMapping("car")//规定了url的写法此时的值可以任意写
public class Controller {
   
 @RequestMapping("get2")
    public void get(Integer id,String name){//此处使用int类型必须赋值  引用类型不用必须赋值最好使用引用类型
        System.out.println(id+name);
    }
    @RequestMapping("get")
               public void get(Integer id){//此处使用int类型必须赋值  引用类型不用必须赋值
 
        System.out.println(id);
 
       }

restful风格进行传参数

restful和普通的get的方法的区别:restful相对比较安全,写法比较简单

restful的地址值的:http://localhost:8080/car2/get2/10/jack/9

其他的url地址值://http://localhost:8080/car/get5?id=10&name=jack&price=9.9

package cn.tedu.controller;
 
import cn.tedu.pojo.Car;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
@RestController
@RequestMapping("car3")
//使用restful风格
public class CarController {
 
   @RequestMapping("get2/{sex}/{id}/{name}")//此地方的参数顺序必须和下面以及地址值都必须一样
public void  get2(@PathVariable String sex,
                 @PathVariable Integer id,
                 @PathVariable String name){
       System.out.println("数据插入成功"+sex+name+id);
      // System.out.println("数据插入成功"+name+id);
    }
   
 
}

spring mvc框架进行传参数

package cn.tedu.controller;
 
import cn.tedu.pojo.Car;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import javax.naming.Name;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
 
//这是一个c层用来接收请求和做出响应
@RestController
//@RequestMapping("car")//规定了url的写法此时的值可以任意写
public class Controller {
    //使用框架接收网站参数
    @RequestMapping("get3")
   public void  get3(Car car){
       System.out.println(car.getSex()+car.getName()+car.getId());
   }
 
}

前后端参数传入并且将数据传入到数据库中

package cn.tedu.controller;
 
import cn.tedu.pojo.Car;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.yaml.snakeyaml.events.Event;
 
import javax.naming.Name;
import java.sql.*;
import java.util.Scanner;
 
@RestController
@RequestMapping("user")
public class UserContoller {
    @RequestMapping("save")
   public void save(Integer id,String name,Integer age) throws Exception {
        System.out.println(id+name+age);
        Class.forName("com.mysql.jdbc.Driver");
        //获取连接
        String url ="jdbc:mysql:///cgb2104?characterEncoding=utf8&useSSL=false&amp;serverTimezone=Asia/Shanghai";
        Connection conn = DriverManager.getConnection(url,"root","root");
        //获取传输器
//        String sql= "insert into user(id,name) values(?,?)";//给指定的字段设置值
        String sql= "insert into user values(?,?,?)";//所有字段设置值
        PreparedStatement ps = conn.prepareStatement(sql);
        //给SQL设置参数
        ps.setInt(1,id);//给第一个?设置值
        ps.setString(2,name);//给第二个?设置值
        ps.setInt(3,age);//给第三个?设置值
        //执行SQL
        int rows = ps.executeUpdate();
        //释放资源 -- OOM(OutOfMemory)
        ps.close();
        conn.close();
    }

到此这篇关于Spring mvc是如何实现与数据库的前后端的连接操作的?的文章就介绍到这了,更多相关Spring mvc与数据库的前后端的连接内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Java/Android 相关文章推荐
JUnit5常用注解的使用
Jul 02 Java/Android
Java反应式框架Reactor中的Mono和Flux
Jul 25 Java/Android
详解JAVA的控制语句
Nov 11 Java/Android
关于MybatisPlus配置双数据库驱动连接数据库问题
Jan 22 Java/Android
SpringCloud Feign请求头删除修改的操作代码
Mar 20 Java/Android
MyBatis配置文件解析与MyBatis实例演示
Apr 07 Java/Android
Java详细解析==和equals的区别
Apr 07 Java/Android
详解Flutter网络请求Dio库的使用及封装
Apr 14 Java/Android
解决Springboot PostMapping无法获取数据的问题
May 06 Java/Android
Java处理延时任务的常用几种解决方案
Jun 01 Java/Android
Android开发手册Chip监听及ChipGroup监听
Jun 10 Java/Android
MyBatis在注解上使用动态SQL方式(@select使用if)
Jul 07 Java/Android
HashMap实现保存两个key相同的数据
Jun 30 #Java/Android
spring boot项目application.properties文件存放及使用介绍
springboot项目以jar包运行的操作方法
Springboot使用Spring Data JPA实现数据库操作
Jun 30 #Java/Android
如何给HttpServletRequest增加消息头
解决ObjectMapper.convertValue() 遇到的一些问题
Jun 30 #Java/Android
Java基础之详解HashSet的使用方法
You might like
php错误提示failed to open stream: HTTP request failed!的完美解决方法
2011/06/06 PHP
apache和php之间协同工作的配置经验分享
2013/04/08 PHP
PHP把数字转成人民币大写的函数分享
2014/06/30 PHP
Symfony2安装第三方Bundles实例详解
2016/02/04 PHP
PHP二维关联数组的遍历方式(实例讲解)
2017/10/18 PHP
PHP实现数组根据某个单元字段排序操作示例
2018/08/01 PHP
转一个日期输入控件,支持FF
2007/04/27 Javascript
25个非常棒的jQuery滑块插件和教程小结
2011/09/02 Javascript
浅谈 jQuery 事件源码定位问题
2014/06/18 Javascript
jQuery实现图片左右滚动特效
2020/04/20 Javascript
实例详解AngularJS实现无限级联动菜单
2016/01/15 Javascript
基于React实现表单数据的添加和删除详解
2017/03/14 Javascript
Vue.js 插件开发详解
2017/03/29 Javascript
解决layer弹层遮罩挡住窗体的问题
2018/08/17 Javascript
[15:58]DOTA2国际邀请赛采访专栏:Tongfu.Sansheng&KingJ,DK.rOtk
2013/08/08 DOTA
[04:03]2014DOTA2西雅图国际邀请赛 LGD战队巡礼
2014/07/07 DOTA
[00:36]DOTA2勇士令状莱恩声望物品——冥晶之厄展示
2018/05/25 DOTA
Python中encode()方法的使用简介
2015/05/18 Python
使用Python正则表达式操作文本数据的方法
2019/05/14 Python
让Python脚本暂停执行的几种方法(小结)
2019/07/11 Python
使用django的objects.filter()方法匹配多个关键字的方法
2019/07/18 Python
Django框架创建mysql连接与使用示例
2019/07/29 Python
Python定时发送天气预报邮件代码实例
2019/09/09 Python
Python类中self参数用法详解
2020/02/13 Python
python如何从键盘获取输入实例
2020/06/18 Python
python如何调用java类
2020/07/05 Python
python利用蒙版抠图(使用PIL.Image和cv2)输出透明背景图
2020/08/04 Python
CSS3伪类选择器:nth-child()
2009/04/02 HTML / CSS
经济实惠的豪华家具:My-Furniture
2019/03/12 全球购物
澳大利亚墨水站Ink Station:墨水和碳粉打印机墨盒
2019/03/24 全球购物
个人自我鉴定
2013/11/07 职场文书
厨师岗位职责
2013/11/12 职场文书
杠杆的科学教学反思
2014/01/10 职场文书
新浪微博实习心得体会
2014/01/27 职场文书
学校德育工作总结2015
2015/05/11 职场文书
创业计划书之干洗店
2019/09/10 职场文书