爱哭的金刚狼 2017-03-15 05:28 采纳率: 0%
浏览 1199

Postgres 数据库模糊检索Inet数据时出问题?

Describe:
Porject: SSM
DB table:
CREATE TABLE public.test
(
id int,
ip inet,
a character varying
)
INSERT INTO public.test(
id, ip, a)
VALUES (1, '1111:0000:0101:000A:0002:0003:0004:0005', 'admin');
INSERT INTO public.test(
id,ip, a)
VALUES (2, '1111:0001:0101:000A:0002:0003:0004:0005', 'admin');
INSERT INTO public.test(
id, ip, a)
VALUES (3, '1111:0011:0101:000A:0002:0003:0004:0005', 'admin');
INSERT INTO public.test(
id, ip, a)
VALUES (4, '1111:0111:0101:000A:0002:0003:0004:0005', 'admin');
INSERT INTO public.test(
id, ip, a)
VALUES (5, '1111:1111:0101:000A:0002:0003:0004:0005', 'admin');

The ip value of the records is '111:0:0101:a:2:3:4:5','111:1:0101:a:2:3:4:5','111:11:0101:a:2:3:4:5','111:111:0101:a:2:3:4:5','111:1111:0101:a:2:3:4:5' in Postgres DB.
We want search the record by ip. The ip input is '1111:0',we want the result is (1-4)records.

  • 写回答

1条回答 默认 最新

  • 爱哭的金刚狼 2017-03-15 05:34
    关注

    自己试了一下
    如果输入:1111:0
    那么数据库中可能匹配的值是1111:0000,1111:000X,1111:00XX,1111:0XXX
    我的SQL这样写的
    select * from test where
    cast((ip)as varchar) like '%1111::%'
    or cast((ip)as varchar) like '%1111:_:%'--1位
    or cast((ip)as varchar) like '%1111:__:%'--2位
    or cast((ip)as varchar) like '%1111:___:%'--3位
    or cast((ip)as varchar) like '%1111:_____'--最后一位
    or cast((ip)as varchar) like '%1111:______'--最后2位
    or cast((ip)as varchar) like '%1111:_______'--最后3位

    不知道还有什么好方法使检索更有效率?

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器