首页 > 数据库 >springboot下postgresql指定schema问题

springboot下postgresql指定schema问题

时间:2024-03-21 11:11:35浏览次数:34  
标签:读取 postgresql springboot 指定 postgres schema dsc Schema

首先明确用的postgresql版本是

PostgreSQL 9.5.25, compiled by Visual C++ build 1800, 64-bit

springboot是

2.3.5.RELEASE。

现有的文档提供的连接数据库配置方式是

url: jdbc:postgresql://IP:端口/数据库名?currentSchema=模式名&stringtype=unspecified

通常postgresql默认指向的Schema是 public。

这次因为用到ArcGis,其默认要读取的Schema是postgres,所以就创建了一个Schema叫postgres的。

项目连接还是指定的public的Schema,后来发现项目读取的表会读到postgres的Schema里,查询配置指定读取Schema,很多文章都是说用的url里的

currentSchema=模式名方式配置,可是不生效。

后来看文章说是读取数据库有个Schema的读取顺序。 查询语句为:

SHOW search_path;

查询结果为:

postgres, "$user", public, topology, sde

第一位成了postgres,以前没有这个Schema,会去读取 $user 的Schema,这个指的是与当前连接数据库的用户名一致的Schema。因为不存在,则读取到了public。

只是比较奇怪的是明明springboot的配置中指定了Schema,但是不生效。

这个问题同样出在mybatis-plus根据数据库表结构生成对应文件的项目中,在这个项目中也需要连接数据库,经测试,同样的url配置Schema不生效,需要额外的指定Schema,才会去读取这个指定的Schema。

// 数据源配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setDbType(DbType.POSTGRE_SQL);
        dsc.setTypeConvert(new PostgreSqlTypeConvert());
        dsc.setDriverName("org.postgresql.Driver");
        dsc.setUsername("postgres");
        dsc.setPassword("postgres");
        dsc.setUrl("jdbc:postgresql://IP:端口/test1?currentSchema=postgres&stringtype=unspecified");//这里指定的sehema没有作用,需要单独指定
        dsc.setSchemaName("public");
        mpg.setDataSource(dsc);

现在Springboot集成postgresql的yml文件没有对应的,url里的指定不生效。暂时还没找到好的解决方法。后续哪位有好方法,麻烦分享下。

以上文字转载:https://blog.51cto.com/u_15127682/4344597

 

标签:读取,postgresql,springboot,指定,postgres,schema,dsc,Schema
From: https://www.cnblogs.com/lzg-blog/p/18086933

相关文章

  • Vue.js+SpringBoot开发服装店库存管理系统
    目录一、摘要1.1项目介绍1.2项目录屏二、功能模块2.1数据中心模块2.2角色管理模块2.3服装档案模块2.4服装入库模块2.5服装出库模块三、系统设计3.1用例设计3.2数据库设计3.2.1角色表3.2.2服装档案表3.2.3服装入库表3.2.4服装出库表四、系统展示五、核......
  • Vue.js+SpringBoot开发高校宿舍调配管理系统
    目录一、摘要1.1项目介绍1.2项目录屏二、功能需求2.1学生端2.2宿管2.3老师端三、系统展示四、核心代码4.1查询单条个人习惯4.2查询我的室友4.3查询宿舍4.4查询指定性别全部宿舍4.5初次分配宿舍五、免责说明一、摘要1.1项目介绍基于JAVA+Vue+Spring......
  • 基于java+springboot+vue实现的电影院选票系统(文末源码+Lw+ppt)23-467
    摘要时代在飞速进步,每个行业都在努力发展现在先进技术,通过这些先进的技术来提高自己的水平和优势,电影院选票系统当然不能排除在外。电影院选票系统是在实际应用和软件工程的开发原理之上,运用java语言,前台Vue框架以及后台SpringBoot框架进行开发。首先要进行需求分析,分析出电......
  • 基于java+springboot+vue实现的智慧养老院管理系统(文末源码+Lw+ppt)23-490
    摘 要智慧养老院管理系统采用B/S架构,数据库是MySQL。网站的搭建与开发采用了先进的java进行编写,使用了springboot框架。该系统从三个对象:由管理员和家属、护工来对系统进行设计构建。主要功能包括:个人信息修改,对家属信息、护工信息、老人入住、外出报备、退房登记、每月餐饮......
  • 基于java+springboot+vue实现的学生管理系统(文末源码+Lw+ppt)23-486
    摘  要学生管理系统的目的是让使用者可以更方便的将人、设备和场景更立体的连接在一起。能让用户以更科幻的方式使用产品,体验高科技时代带给人们的方便,同时也能让用户体会到与以往常规产品不同的体验风格。与安卓,iOS相比较起来,学生管理系统在流畅性,续航能力,等方方面面都有......
  • 基于java+SpringBoot+Vuel的制造装备物联及生产管理ERP系统设计与实现
    基于java+SpringBoot+Vuel的制造装备物联及生产管理ERP系统设计与实现开发语言:Java数据库:MySQL技术:SpringBoot+MyBatis工具:IDEA/Ecilpse、Navicat、Maven系统展示前台展示系统简介制造装备物联及生产管理ERP系统在对开发工具的选择上也很慎重,为了便于开发实现,选......
  • SpringBoot:如何读取 .sql文件的内容并执行
    摘要:在复杂查询、统计等应用场景,直接写sql并执行是一种高效的方法。此文记录工作中解决的将查询统计sql直接写在文件中,代码中读取相应的文件即可获得要执行的sql。要点:.sql文件要放到Resource目录下,读取时路径要正确一种正确的方式和关键代码这里提供的是一种尝试过的......
  • springboot实现拦截器
    在springboot中实现拦截器分为两步:1、创建普通拦截器,需要实现HandlerInterceptor并重写接口中相关方法;2、将上一步创建的拦截器加入到springboot配置中,配置拦截规则下面是相关代码和demo请求:定义一个普通拦截器:importorg.springframework.stereotype.Component;importorg......
  • SpringBoot Maven继承
    Maven继承方案一特点:全面<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.3.RELEASE</version></parent>方案二特点:不用继承父模块,解决了单继承问题;即可以继承......
  • MySQL InnoDB Instant schema 变更注意点
    在MySQL8.0.12中为DDL引入了新的算法,在修改表的定义的时候不会阻塞。第一个instant操作是在表的最后增加一个列,这是腾讯游戏团队贡献的。在8.0.29中,官方增加在任意位置增加或删除列的instant操作。本文要讲的是盲目使用该特性会带来的危害。 默认算法从MySQL8.0......