首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Postgresql数据过滤为使用相似操作符的joininbg 2表

Postgresql数据过滤为使用相似操作符的joininbg 2表
EN

Stack Overflow用户
提问于 2022-11-18 14:51:21
回答 1查看 15关注 0票数 1

我在Postgresql 13的两个表中有JSON数据,我试图使用like操作符连接它们。但是由于字段中的数据是JSON,所以我得到了一个语法错误。

错误:语法错误在"DepartmentId“第6行或附近:.ta::json->‘dv_DeptId’类‘%e.json_data::json->’Department.

SQL小提琴供参考

以下是我的查询:

代码语言:javascript
复制
CREATE SCHEMA dbo;

CREATE TABLE dbo.Emp
(
  EmpId varchar(50),
  json_data varchar
);


INSERT INTO dbo.Emp (EmpId,json_data) values ('E1', '{"EmpId":{"value":"E1","display_value":"E1"},"DepartmentId":{"value":"D1","display_value":"D1"}}')
  ,('E2', '{"EmpId":{"value":"E2","display_value":"E2"},"DepartmentId":{"value":"D2","display_value":"D2"}}');
  
select * from dbo.Emp;

CREATE TABLE dbo.Dept
(
  DeptId varchar(50),
  json_data varchar

);

INSERT INTO dbo.Dept (DeptId, json_data) values ('D1', '{"DeptId":"D1","dv_DeptId":"D1","DeptName":"IT","dv_DeptName":"IT"}}')
  ,('D2', '{"DeptId":"D2","dv_DeptId":"D2","DeptName":"Marketing","dv_DeptName":"Marketing"}}')
  ,('D3', '{"DeptId":"D3","dv_DeptId":"D3","DeptName":"HR","dv_DeptName":"HR"}}');

SELECT * FROM dbo.Dept;

select  
    e.json_data::json->'DepartmentId' ->> 'value' as "Emp_DepartmentId"
  , d.json_data::json->>'dv_DeptId' as "Dept_DepartmentId"
    from dbo.Emp e
    LEFT JOIN dbo.Dept as d
    ON d.json_data::json->>'dv_DeptId' like '%e.json_data::json->'DepartmentId' ->> 'value'%' -- throws syntax error

预期输出

代码语言:javascript
复制
Emp_DepartmentId  Dept_DepartmentId
D1                   D1
D2                   D2
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-11-18 15:07:32

通过将like连接到'%',您可以构造稍微不同的'%'语句,它将工作。

[医]小提琴

代码语言:javascript
复制
select  
   e.json_data::json->'DepartmentId' ->> 'value' as "Emp_DepartmentId"
   , d.json_data::json ->> 'dv_DeptId' as "Dept_DepartmentId"
    from dbo.Emp e
    LEFT JOIN dbo.Dept as d
    ON d.json_data::json ->> 'dv_DeptId' like '%' || cast(e.json_data::json->'DepartmentId' ->> 'value' as varchar) || '%'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74491471

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档