Précédent   Forum des professionnels en informatique > Bases de données > MS SQL-Server
MS SQL-Server Forum Microsoft SQL-Server. Avant de poster -> FAQ SQL-Server, Tutoriels SQL-Server
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 11/01/2011, 09h33   #1
Invité de passage
 
Inscription : mai 2007
Messages : 4
Détails du profil
Informations forums :
Inscription : mai 2007
Messages : 4
Points : 0
Points : 0
Par défaut traitement chaine de caractères dans la création d'une vue

Bonjour,
n'étant pas un expert en SQL, j'aurais besoin d'un petit coup de main.

Alors il faudrait que je puisse faire une vue de x colonnes où, dans l'une d'elle, j' extrais une certaine valeur d'une chaine de caractère d'un enregistrement.

un exemple:

voilà un enregistrement "INFO" d'une table:

valeur1_[1[_valeur2_[2[_valeur3[10[

valeur1, valeur2, valeur3 sont les noms de variables et les valeurs sont entre les crochés ouverts
valeur1 = 1
valeur2 = 2
valeur3 = 10

Il faudrait que j'extrais la valeur de la variable valeur2 dans ma vue afin d'avoir l'information directement accessible.

J'espère avoir été assez clair dans mes explications...
Merci d'avance.
dudu40 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/01/2011, 11h18   #2
Membre Expert
 
Inscription : janvier 2010
Messages : 1 084
Détails du profil
Informations personnelles :
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : janvier 2010
Messages : 1 084
Points : 1 573
Points : 1 573
Bonjour,

Effectuer des manipulations de chaines de caractères n'est pas le fort des SGBDR. D'où proviennent ces données ? n'avez vous pas la possibilité d'effectuer un traitement en amont (avant insertion)

Sinon vous trouverez sur le net des fonctions de split mais si vous ne cherchez qu'une seule valeurs dans la chaine, il y aura surement plus efficace !

Comptez vous indexer la vue que vous voulez créer ?
aieeeuuuuu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/01/2011, 12h11   #3
Modérateur

 
Avatar de elsuket
 
Homme Nicolas Souquet
Administrateur de base de données
Inscription : janvier 2005
Messages : 4 665
Détails du profil
Informations personnelles :
Nom : Homme Nicolas Souquet
Âge : 30
Localisation : Thaïlande

Informations professionnelles :
Activité : Administrateur de base de données
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : janvier 2005
Messages : 4 665
Points : 8 707
Points : 8 707
Bonjour,

La requête qui permet d'extraire la valeur 2 est la suivante :

Code :
1
2
3
4
5
6
7
DECLARE @toto varchar(1024) = 'valeur1_[1[_valeur2_[2[_valeur3[10['
SELECT SUBSTRING
	(
		@toto
		, CHARINDEX('_valeur2_[', @toto) + LEN('_valeur2_[')
		, CHARINDEX('[_valeur3[', @toto) - (CHARINDEX('_valeur2_[', @toto) + LEN('_valeur2_['))
	)
Vous pouvez la transformer en fonction de table en ligne :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
CREATE FUNCTION fct_extract_valeur2
	(@_chaine varchar(max))
RETURNS TABLE
AS
RETURN
(
	SELECT SUBSTRING
		(
			@_chaine
			, CHARINDEX('_valeur2_[', @_chaine) + LEN('_valeur2_[')
			, CHARINDEX('[_valeur3[', @_chaine) - (CHARINDEX('_valeur2_[', @_chaine) + LEN('_valeur2_['))
		) AS valeur2
)
Ce qui vous permet ensuite de l'utiliser dans la définition de votre vue à l'aide de CROSS APPLY, ou éventuellement OUTER APPLY si vous voulez retourner les lignes pour lesquelles la fonction retourne NULL :

Code :
1
2
3
4
5
6
CREATE VIEW	maVue
AS
SELECT		T.mesColonnes
		, EV2.valeur2
FROM		dbo.maTable AS T
CROSS APPLY	dbo.fct_extract_valeur2(T.maColonneChaine) AS EV2
Mais comme vous l'a dit aieeeuuuuu, le mieux est de faire cela en amont, dans le processus d'import des données.
Notez que vous pouvez faire cela avec une colonne calculée, mais il faut alors transformer la fonction que je vous ai donné en fonction scalaire :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
CREATE FUNCTION fct_extract_valeur2
	(@_chaine varchar(max))
RETURNS int
AS
BEGIN
	DECLARE	@valeur2 int
 
	SELECT @valeur2 = SUBSTRING (
					@_chaine
					, CHARINDEX('_valeur2_[', @_chaine) + LEN('_valeur2_[')
					, CHARINDEX('[_valeur3[', @_chaine) - (CHARINDEX('_valeur2_[', @_chaine) + LEN('_valeur2_['))
					)
	RETURN @valeur2
END
Et pour ajouter la colonne calculée à la table :

Code :
1
2
ALTER TABLE dbo.maTable
ADD maColonne AS (dbo.fct_extract_valeur2(maColonneChaine))
Et pour l'indexation, cela dépend de votre requête d'interrogation

@++
__________________
En bases de données relationnelles SQL, il n'y a ni tableaux, ni enregistrements, ni champs: il y a des tables, des lignes et des colonnes.
Blog | Profil| Consulter ou télécharger les fichiers d'aide de SQL Server, des versions 2000 à 2012
elsuket est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2011, 22h37   #4
Invité de passage
 
Inscription : mai 2007
Messages : 4
Détails du profil
Informations forums :
Inscription : mai 2007
Messages : 4
Points : 0
Points : 0
Merci pour ces informations qui m'ont bien servi!!
J'ai adapté un peu la requête qui permet d'extraire la valeur, car en fait les noms de variables valeurs sont générées par un progiciel et portent en fait des noms totalement différents.
dudu40 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 19h17.


 
 
 
 
Partenaires

Hébergement Web