org.postgresql.util.PSQLException

news2024/9/25 21:19:50

1.使用springboot整合postgresql时报错:org.postgresql.util.PSQLException

1.1依赖

使用spring boot和postgresql搭建简单demo

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.2.0</version>
        </dependency>

1.2 配置postgresql数据库

server:
  port: 8005
spring:
  application:
    name: postgres
  datasource:
    driver-class-name: org.postgresql.Driver
    url: jdbc:postgresql://localhost:5432/test
    username: postgres
    password: root

1.3 启动类

@SpringBootApplication
@MapperScan("com.test.postgre.mapper")
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
}

1.4 实体

@Data
@Table(name = "user")
public class User {

    @TableId(type = IdType.AUTO)
    private Integer id;

    private String name;

    private Integer age;
}

1.5 controller

@RestController
@Controller
@RequestMapping("user")
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("findAll")
    public ResponseEntity findAll(){
        return userService.findAll();
    }
}

1.6 mapper

@Repository
public interface UserMapper extends BaseMapper<User> {
    @Select("SELECT * FROM public.\"user\"")
    List<User> selectAll();
}

1.7实现类

@Service
@Slf4j
public class UserServiceImpl implements UserService {

    @Autowired
    private UserMapper userMapper;

    @Override
    public ResponseEntity findAll() {
        List<User> list = userMapper.selectList(null);
        //List<User> list = userMapper.selectAll();

        log.info("list:{}",list);
        return ResponseEntity.ok(list);
    }
}

这看着没什么问题,但是启动后,调用接口http://localhost:8005/user/findAll,报500,控制台报错如下
在这里插入图片描述
使用mubatisplus的封装SQL提示id不存在,
然后改用自己写sql:
在这里插入图片描述

@Repository
public interface UserMapper extends BaseMapper<User> {
    @Select("SELECT * FROM public.\"user\"")
    List<User> selectAll();
}

sql是按照postgresql的可视化工具-pgAdmin4中查询sql复制过来的,
在这里插入图片描述
重启服务,发现接口返回成功
在这里插入图片描述

2.疑问

1.为啥使用mybatisplus的封装语句不行?少了什么吗,如果是mysql,这样的流程是没问题的,有大佬指点一下吗?

3 补充增删改接口代码

3.1 controller

 @PostMapping("add")
    public ResponseEntity add(@RequestBody User user){
        return userService.add(user);
    }

    @PostMapping("update")
    public ResponseEntity update(@RequestBody User user){
        return userService.update(user);
    }

    @DeleteMapping("delete")
    public ResponseEntity delete(Integer id){
        return userService.delete(id);
    }

3.2 service

public interface UserService {
    ResponseEntity findAll();

    ResponseEntity add(User user);

    ResponseEntity update(User user);

    ResponseEntity delete(Integer id);
}

3.3实现类

@Override
    public ResponseEntity add(User user) {
        userMapper.insertUser(user.getName(),user.getAge());
        return ResponseEntity.ok("插入成功");
    }

    @Override
    public ResponseEntity update(User user) {
        userMapper.updateUser(user.getId(),user.getName(),user.getAge());
        return ResponseEntity.ok("修改成功");
    }

    @Override
    public ResponseEntity delete(Integer id) {
        int i = userMapper.deleteUserById(id);
        log.info("delete {}",i);
        return ResponseEntity.ok("删除成功");
    }

3.4 mapper

@Insert("INSERT INTO public.\"user\"(name, age) VALUES ( #{name}, #{age});")
    void insertUser(String name,Integer age);

    @Update("UPDATE public.\"user\" SET name=#{name}, age=#{age} WHERE id=#{id}")
    void updateUser(Integer id, String name, Integer age);

    @Delete("DELETE FROM public.\"user\" WHERE id=#{id}")
    int deleteUserById(Integer id);

3.5 疑问

测试删除时,在可视化页面pgAdmin4中同样的sql,删除成功,但是在代码中执行时,删除记录为0条,求助大佬解答!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/382309.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Git概述

查看git版本&#xff1a; git --version1、Git概述 Git 是一个免费的、开源的分布式版本控制系统&#xff0c;可以快速高效地处理从小型到大型的各种项目。 Git 易于学习&#xff0c;占地面积小&#xff0c;性能极快。它具有廉价的本地库&#xff0c;方便的暂存区域和多个工作…

【C++基础入门】运算符、程序流程结构(if语句,for循环,switch语句等)

一&#xff1a;运算符 作用&#xff1a;用于执行代码的运算 运算符类型作用算术运算符用于处理四则运算赋值运算符用于将表达式的值赋给变量比较运算符用于表达式的比较&#xff0c;并返回一个真值或假值逻辑运算符用于根据表达式的值返回真值或假值 1.1 算术运算符 作用 &a…

PDF编辑/PDF浏览/PDF打印:PDFPrinting.NET Crack

PDFPrinting.NET高级 PDF 编辑库&#xff0c;可完全控制您的 PDF 创建工作流程 我们为 PDF 创建和编辑提供高级和低级 API。从简单的文档拆分到单个元素的精确删除。 从头开始创建 PDF 文档。 编辑现有文件。 支持创建、插入或删除 PDF 元素。 允许更改 PDF 的加密和压缩。 自…

计算机组成原理4小时速成7:存储器和cpu的连接,位扩展,字扩展,存储器的校验,汉明码编码纠错检错

计算机组成原理4小时速成7&#xff1a;存储器和cpu的连接&#xff0c;位扩展&#xff0c;字扩展&#xff0c;存储器的校验&#xff0c;汉明码编码纠错检错 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都…

C/C++每日一练(20230302)

目录 1. 个位数是6&#xff0c;且能被3整除的五位数共有多少个&#xff1f; ☆ 2. 不同方式求n的阶乘 ★ 3. 报数游戏 ★☆ 1. 个位数是6&#xff0c;且能被3整除的五位数共有多少个&#xff1f; 答案&#xff1a; 3000 &#xff0c;代码略 2. 不同方式求n的阶乘 求n的…

sdwan方案有哪些 SD-WAN怎么搭建

随着sdwan网络架构的形成到目前的广泛应用到各行业之中&#xff0c;足见sdwan方案已经逐步的走向成熟。sdwan软件定义网络可在包括公共Internet&#xff0c;MPLS和宽带在内的标准网络传输服务上运行&#xff0c;解决了很多跨区域之间网络传输数据的难题。那么&#xff0c;sdwan…

软件测试4

一 form表单标签 1.form表单标签里面就是所有用户填写的表单数据&#xff1b; action“xxx.py”把表单数据提交给哪一个后台程序去处理 method“post” 传递数据时候的方式方法&#xff0c;post代表隐式提交数据、get明文传送数据 2.input标签的type类型 type“text” 普通的输…

优思学院|解密六西格玛:探索DMAIC和DMADV之间的区别

六西格玛方法中最为广泛使用的两种方法是DMAIC和DMADV。这两种方法都是为了让企业流程更加高效和有效而设计的。虽然这两种方法有一些重要的共同特点&#xff0c;但它们并不可以互相替代&#xff0c;并且被开发用于不同的企业流程。在更详细地比较这两种方法之前&#xff0c;我…

扬帆优配|突发利空,千亿巨头重挫!凭“一己之力”

马斯克效应持续凸显&#xff0c;稀土永磁板块早盘大跌&#xff0c;千亿市值的北方稀土跌超4%。 近来&#xff0c;马斯克凭“一己之力”带火A股卫星互联网、毫米波雷达两大概念板块&#xff0c;多只相关个股闻风大涨。 今日&#xff0c;马斯克效应在A股再度应验。在当地时间3月…

功能测试前还需要做哪些准备?

概述 在项目管理流程中&#xff0c;有几个关键阶段&#xff1a; 需求阶段 开发阶段 测试阶段 上线阶段 其中的需求阶段和开发阶段是最为重要的&#xff0c;一个是设计&#xff0c;定义这个功能如何运作&#xff0c;一个是执行与实现&#xff0c;这两个阶段把控好了&#…

从安卓系统USB升级包里提取system.img、boot.img和recovery.img在内的镜像文件

1.前言 如果你拿到一个USB升级包&#xff0c;你会发现升级包的结构基本相似。 但是里面并不是直接就有包括system.img、boot.img和recovery.img在内的镜像文件。 如果我们需要在Android手机上获取Magisk。提取内核&#xff08;boot.img&#xff09;就至关重要。当然其他镜像根…

不能去演唱会现场就多听听耳机里的他们,教你用python来实现一个音乐播放器

前言 最近可以说大麦网很知名了&#xff0c;哈哈还有好多想要用Python来搞抢票脚本的 怎么说呢也不是不行&#xff0c;但是咱今天可不是来搞这个的&#xff0c;我可不抢票&#xff0c;抢了都去不了&#xff0c;上班搞钱啊铁铁们 咱就是说去不了现场&#xff0c;就多听听手机…

实例分割 mask loss异常值,训练过程报错 debug记录

实例分割包含了目标检测,和检测框里的语义分割。 在搭建好一个模型后,训练过程中遇到了mask loss异常值,目标框消失不见,validation过程报错的情况,这里记录一下对这些问题的分析过程和debug记录。 首先分析一下mask loss异常值的问题。 mask loss用的是BCE loss。 mask…

dva( 轻量级的应用框架 )

dva核心知识与实战运用 dva 首先是一个基于 redux 和 redux-saga 的数据流方案&#xff0c;然后为了简化开发体验&#xff0c;dva 还额外内置了 react-router 和 fetch&#xff0c;所以也可以理解为一个轻量级的应用框架! 介绍 | DvaJS 易学易用&#xff0c;仅有 6 个 api&…

易基因-MeRIP-seq揭示衰老和神经变性过程中m6A RNA甲基化修饰的保守下调机制

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。2023年02月22日&#xff0c;《美国国家科学院院刊》(Proc Natl Acad Sci USA)期刊发表了题为“Conserved reduction of m6A RNA modifications during aging and neurodegeneration is lin…

机器学习:学习KMeans算法,了解模型创建、使用模型及模型评价

机器学习&#xff1a;学习KMeans算法&#xff0c;了解模型创建、使用模型及模型评价 作者&#xff1a;AOAIYI 作者简介&#xff1a;Python领域新星作者、多项比赛获奖者&#xff1a;AOAIYI首页 &#x1f60a;&#x1f60a;&#x1f60a;如果觉得文章不错或能帮助到你学习&#…

android 动态加载jar包

什么时候需要用到动态加载jar包呢&#xff1f; 减少apk本身大小&#xff0c;某些界面才需要用jar里的功能jar中的功能可以独立开发&#xff0c;不要依赖其它的东西&#xff0c;能适用各个项目和第三方公司合作&#xff0c;人家不提供项目源码给你&#xff0c;但又要开发他们使…

MySQL workbench的基本操作

1. 创建新的连接 hostname主机名输入“local host”和“127.0.0.1”效果是一样的&#xff0c;指的是本地的服务器。 需要注意的是&#xff0c;此处的密码在安装软件的时候已经设定。 点击【Test Connection】&#xff0c;测试连接是否成功。 创建完的连接可以通过&#xff0c…

汇编指令学习(ADD,SUB,MUL,DIV,XADD,INC,DEC,NEG)

一、ADD加法操作指令将eax置1&#xff0c;ebx置2&#xff0c;运行下面命令&#xff0c;将结果保存到eaxadd eax,ebx扩展&#xff1a;adc需要再加上CF标志位的值adc eax&#xff0c;ebx二、SUB减法操作指令将eax置3&#xff0c;ebx置2&#xff0c;运行下面命令&#xff0c;将结果…

java异常分类和finally代码块中return语句的影响

首先看一下java中异常相关类的继承关系&#xff1a; 引用 1、分类 异常可以分为受查异常和非受查异常&#xff0c;Error和RuntimeException及其所有的子类都是非受查异常&#xff0c;其他的是受查异常。 两者的区别主要在&#xff1a; 受检的异常是由编译器&#xff08;编译…