Oracle
 sql >> Base de données >  >> RDS >> Oracle

Données de requête Oracle où la valeur de la colonne avec virgule pour vérifier que la valeur contient ou non

Vous devez rechercher une sous-chaîne entourée par les délimiteurs :

SELECT PROFILEID
FROM   WA_BT_TBL_PROFILE P
WHERE  ', ' || P.ALLOWED_IP_ADDRESS || ', ' LIKE '%, 192.168.183.28, %';

Cependant, une meilleure façon serait de modifier votre table de base de données afin de ne pas stocker plusieurs éléments dans une seule valeur :

CREATE TABLE Allowed_IP_Addresses(
  PROFILEID          VARCHAR2(20)
                     CONSTRAINT AllowIP__ProfileID__FK REFERENCES WA_BT_TBL_PROFILE( PROFILEID ),
  CLASSA             NUMBER(3,0),
  CLASSB             NUMBER(3,0),
  CLASSC             NUMBER(3,0),
  CLASSD             NUMBER(3,0),
  IP_ADDRESS         VARCHAR2(15)
                     GENERATED ALWAYS AS (CLASSA||'.'||CLASSB||'.'||CLASSC||'.'||CLASSD) VIRTUAL,
  CONSTRAINT AllowIP__P_A_B_C_D__PK PRIMARY KEY ( PROFILEID, CLASSA, CLASSB, CLASSC, CLASSD )
);

Ensuite, vous pouvez stocker les valeurs individuellement (et rechercher facilement des plages de sous-réseaux) et les joindre à la table de profil si nécessaire.