Précédent   Forum des professionnels en informatique > Bases de données > Langage SQL
Langage SQL Forum d'entraide sur le langage SQL et sur les questions liées à la conception de schéma (DDL). Cours SQL
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 30/09/2011, 15h33   #1
Invité de passage
 
Inscription : juillet 2010
Messages : 4
Détails du profil
Informations forums :
Inscription : juillet 2010
Messages : 4
Points : 0
Points : 0
Par défaut Requête sql

Voila je vais faire simple je me prends la tête depuis 3 jours sur une requête sql si une âme charitable voulait bien m'aider.
La requête comprend 4 tables dont je joins les descriptions si dessous.
Je développe un module Joomla pour le composant sobi2


Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
-- La table sobi2_fields qui contient tous les champ perso que l'on peut créer depuis l'admin de joomla
 
CREATE TABLE IF NOT EXISTS `jos_sobi2_fields` (
  `fieldid` int(11) NOT NULL AUTO_INCREMENT,
  `fieldType` int(11) DEFAULT NULL,
  `wysiwyg` tinyint(1) DEFAULT NULL,
  `fieldDescription` text,
  `explanation` text,
  `is_free` tinyint(1) DEFAULT NULL,
  `payment` double DEFAULT NULL,
  `fieldChars` int(11) DEFAULT NULL,
  `fieldRows` int(11) DEFAULT NULL,
  `fieldColumns` int(11) DEFAULT NULL,
  `preferred_size` int(11) DEFAULT NULL,
  `CSSclass` text,
  `enabled` tinyint(1) DEFAULT NULL,
  `isEditable` tinyint(1) DEFAULT NULL,
  `is_required` tinyint(1) DEFAULT NULL,
  `in_promoted` tinyint(1) DEFAULT NULL,
  `in_vcard` tinyint(1) DEFAULT NULL,
  `in_details` tinyint(1) NOT NULL,
  `position` int(11) DEFAULT NULL,
  `in_search` int(2) NOT NULL,
  `with_label` tinyint(1) NOT NULL,
  `in_newline` tinyint(1) NOT NULL,
  `isUrl` int(2) NOT NULL,
  `checked_out` int(11) NOT NULL,
  `checked_out_time` datetime NOT NULL,
  `displayed` tinyint(1) NOT NULL,
  PRIMARY KEY  (`fieldid`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=44 ;
 
 
-- La table sobi2_fields_data qui contient toutes les données de ces champs perso
 
CREATE TABLE IF NOT EXISTS `jos_sobi2_fields_data` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `fieldid` int(11) DEFAULT NULL,
  `data_txt` text,
  `data_bool` tinyint(1) DEFAULT NULL,
  `data_int` int(20) DEFAULT '0',
  `data_float` float DEFAULT '0',
  `data_char` varchar(255) NOT NULL,
  `itemid` int(11) DEFAULT NULL,
  `expiration` datetime DEFAULT NULL,
  PRIMARY KEY  (`id`),
  KEY `itemid` (`itemid`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=182 ;
 
 
-- La table sobi2 item qui contient les entrées de l'annuaire
 
CREATE TABLE IF NOT EXISTS `jos_sobi2_item` (
  `itemid` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) DEFAULT NULL,
  `hits` int(11) DEFAULT NULL,
  `visits` int(11) DEFAULT NULL,
  `published` tinyint(1) DEFAULT NULL,
  `confirm` tinyint(1) NOT NULL,
  `approved` tinyint(1) NOT NULL,
  `archived` tinyint(1) DEFAULT NULL,
  `publish_up` datetime DEFAULT NULL,
  `publish_down` datetime DEFAULT NULL,
  `checked_out` int(11) DEFAULT NULL,
  `checked_out_time` datetime NOT NULL,
  `ordering` int(11) DEFAULT NULL,
  `owner` int(11) NOT NULL,
  `icon` varchar(200) NOT NULL,
  `image` varchar(200) NOT NULL,
  `background` varchar(100) DEFAULT NULL,
  `options` text,
  `params` text,
  `ip` varchar(15) NOT NULL,
  `last_update` datetime NOT NULL,
  `updating_user` int(11) NOT NULL,
  `updating_ip` varchar(15) NOT NULL,
  `metakey` varchar(200) NOT NULL,
  `metadesc` text NOT NULL,
  PRIMARY KEY  (`itemid`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=13 ;
 
 
-- La table sobi2_language qui contient toutes les correspondances de langue du composant
 
CREATE TABLE IF NOT EXISTS `jos_sobi2_language` (
  `langKey` varchar(50) NOT NULL DEFAULT '',
  `langValue` varchar(255) NOT NULL DEFAULT '',
  `description` text,
  `sobi2Section` varchar(10) NOT NULL DEFAULT '',
  `fieldid` int(11) DEFAULT NULL,
  `sobi2Lang` varchar(50) NOT NULL DEFAULT '',
  PRIMARY KEY  (`langKey`,`sobi2Lang`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
Si besoin je peux joindre des données d'exemple.

Donc mon probleme j'ai créé un champ perso premium sont jos_sobi2_language.langKey = field_prem sont jos_sobi2_language.langValue = Premium, sont jos_sobi2_language.fieldid = 43, sont jos_sobi2_fields_data.data_txt peut etre 0 ou 1.

J'ai donc besoin de recupérer les entrées de jos_sobi2_item que si le jos_sobi2_fields_data.data_txt = 1.

je ne sait pas si j'ai été bien clair.
Un peu d'aide svp
Un carambar pour le gagnant
jenova11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/09/2011, 15h45   #2
Membre Expert
 
Homme Sylvain Devidal
Chef de projets Générix
Inscription : février 2010
Messages : 1 062
Détails du profil
Informations personnelles :
Nom : Homme Sylvain Devidal
Âge : 33
Localisation : France, Rhône (Rhône Alpes)

Informations professionnelles :
Activité : Chef de projets Générix
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : février 2010
Messages : 1 062
Points : 1 515
Points : 1 515
Avec moins de fautes de français (j'ai mis 15 minutes à comprendre tes "sont") et une description des clés étrangères ainsi que la requête que t'as commencé à écrire, ça nous aiderait vachement à te répondre...
StringBuilder est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/09/2011, 15h49   #3
Invité de passage
 
Inscription : juillet 2010
Messages : 4
Détails du profil
Informations forums :
Inscription : juillet 2010
Messages : 4
Points : 0
Points : 0
Pour les requêtes justement je n'arrive a rien, je suis vraiment débutante qu'est-ce qu'une clé étrangère ?
jenova11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/09/2011, 15h58   #4
Membre Expert
 
Homme Sylvain Devidal
Chef de projets Générix
Inscription : février 2010
Messages : 1 062
Détails du profil
Informations personnelles :
Nom : Homme Sylvain Devidal
Âge : 33
Localisation : France, Rhône (Rhône Alpes)

Informations professionnelles :
Activité : Chef de projets Générix
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : février 2010
Messages : 1 062
Points : 1 515
Points : 1 515
Une clé étrangère, c'est ce qui permet de savoir comment faire la jointure entre deux tables :

Mettons une table "personne" (id, nom, prenom, sexe)
Et une table "maison" (id, ardresse, surface)

Là, comme ça, impossible de savoir qui habite dans quelle maison.

Donc on rajoute un champ "maison_id" dans la table "personne", afin de dire "ben cette personne, elle habite dans la maison qui a pour id = maison_id".

C'est ça une clé étrangère.
Si tu n'en a pas dans tes tables, c'est peut-être pour ça que tu n'arrives pas à faire ta requête... Mais sans clé étrangère, personne ne pourra t'aider !
StringBuilder est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/09/2011, 16h38   #5
Membre Expert
 
Homme
Responsable de service informatique
Inscription : janvier 2009
Messages : 1 092
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 38
Localisation : France

Informations professionnelles :
Activité : Responsable de service informatique
Secteur : Boutique - Magasin

Informations forums :
Inscription : janvier 2009
Messages : 1 092
Points : 1 898
Points : 1 898
Bonjour,
A vu de nez, je dirai que la colonne qui fait le lien entre jos_sobi2_fields et jos_sobi2_fields_data est fieldid (vu que c'est la clé primaire de jos_sobi2_fields).
Je rejoins StringBuilder, il faudrait déclarer la clé étrangère dans jos_sobi2_fields_data, ne serait-ce que pour l'intégrité référentielle. De plus celà t'aiderai à trouver les liens entre les tables, et donc à écrire tes requêtes.

Donc ici tu dois faire une jointure entre jos_sobi2_fields_data et jos_sobi2_fields.

En cherchant bien sur le site tu devrais trouver les tutoriels qui vont bien, que ce soit pour les clés étrangères ou les jointures.

Voilou, comme j'aime pas les carambars, je te laisse écrire la requête ...

Tatayo.
tatayo 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 03h41.


 
 
 
 
Partenaires

Hébergement Web