MySQL: Problemas con JOINs entre versión 4 y 5
11 de Abril de 2008 en Programación, SQL
Lecturas: 3,747
buy generic clomid no rx cialis cheapest clomid order levitra online where to buy accutane find discount cialis online viagra tablets cheapest accutane prices buy acomplia cheap low cost viagra lasix online stores discount cialis no rx viagra india acomplia sale viagra approved viagra pharmacy cialis pills soma without prescription buy viagra in canada find no rx viagra buy zithromax find viagra clomid online stores discount acomplia cheap clomid tablets buy generic levitra purchase levitra online cialis buy cialis india cheapest cialis prices zithromax without prescription acomplia online stores buy cheapest viagra on line propecia online cheap purchase soma online synthroid without prescription cost viagra levitra pills viagra overnight shipping cheap viagra internet buy viagra us buy generic accutane synthroid sale cheap lasix online purchase cialis without prescription buy synthroid cheap viagra cheap drug cialis for order buy cheap zithromax viagra cheap price order accutane online buy viagra low price zithromax prices order propecia online discount clomid order cialis on internet online soma order cialis no prescription cheap propecia online acomplia pills buy accutane without prescription cialis australia price of soma cialis sales buy soma without prescription no prescription cialis lasix generic cheap cialis on internet cheap clomid online synthroid online cheap purchase clomid online where to buy synthroid cheap levitra online discount cialis overnight delivery viagra australia buying viagra online zithromax for sale viagra cost viagra pills buy cialis lowest price price of clomid cialis side effects lasix for sale cheapest generic cialis find viagra on internet levitra online stores cialis overnight shipping viagra online review free cialis cialis approved buy cheapest viagra cheap viagra online where to buy levitra order cialis from canada cialis pharmacy order soma levitra cheap viagra without rx clomid cheap cheap generic synthroid where to buy propecia buy generic synthroid order lasix online where to order viagra buy accutane cheap cheap accutane tablets cheapest synthroid prices cheap viagra in uk synthroid online stores accutane prescription where to order cialis order viagra on internet sale viagra buy cheap clomid buy cialis low price find cialis no prescription required viagra internet buy discount viagra best price for viagra cheap propecia clomid without a prescription buy viagra without prescription discount lasix levitra for sale buy clomid certified cialis where to buy acomplia buy cheap accutane online buy cheapest viagra online buy cheapest cialis on line lowest price propecia viagra in uk buy no rx viagra cheapest clomid prices order cialis in us cheap acomplia tablets buy lasix without prescription discount viagra overnight delivery cheap cialis internet cialis overnight no prescription viagra buy synthroid viagra price find cheap cialis online order clomid online best price for cialis viagra purchase purchase cialis online online lasix cheapest acomplia prices zithromax without a prescription best price viagra cialis order accutane cheap buy cialis in us buy viagra on internet purchase clomid clomid cialis pharmacy online cialis purchase cheap lasix tablets cialis generic cheapest viagra price zithromax no prescription zithromax cheap cialis cheap drug buy cialis in canada cheap zithromax tablets buy clomid without prescription lowest price lasix acomplia discount cialis online viagra tablet synthroid generic propecia no prescription buy generic zithromax order viagra in us purchase viagra no rx approved viagra pharmacy purchase viagra online soma generic accutane cialis no rx required online synthroid purchase viagra overnight delivery discount cialis buy no rx cialis viagra generic buy cialis us clomid prescription acomplia prices purchase lasix online buy cheap synthroid viagra online pharmacy buy cheap clomid online lasix cheap cheap generic clomid viagra buy drug clomid pharmacy propecia without prescription synthroid online accutane sale levitra no prescription online accutane price of cialis synthroid without a prescription buy generic viagra viagra in australia cheapest zithromax prices buy lasix discount zithromax cheapest levitra cost of cialis cheap viagra in usa propecia online stores buy zithromax cheap sale cialis find cheap viagra viagra us cheap clomid cialis online stores soma no prescription buy cialis online where to buy viagra generic viagra buy cialis internet buy levitra cheap order cialis no prescription required cheap levitra tablets buy cialis overnight delivery buy viagra generic lasix online cheap cialis no prescription acomplia cheap order viagra no prescription required cheapest levitra prices discount viagra online viagra where to buy zithromax buy cheap acomplia purchase viagra accutane for sale generic acomplia cheap viagra no prescription compare viagra prices generic zithromax buy clomid online propecia cheap levitra prescription buy clomid cheap viagra in malaysia acomplia pharmacy acomplia for sale order viagra cheap online online viagra buy acomplia without prescription lowest price soma discount cialis online lasix prices cialis cheapest price cheap accutane online buy synthroid without prescription find cialis without prescription accutane without prescription buy acomplia cialis cheap cheap viagra from usa online cialis clomid discount cheap cialis in usa soma online cheap cialis without a prescription where to buy soma purchase propecia online cialis sale buy cheap soma find viagra online cheap soma online cialis free sample lowest price viagra buy cialis on line viagra from canada online pharmacy cialis levitra drug viagra online purchase drug cialis buy zithromax online buy propecia lasix pharmacy accutane generic clomid online cheap soma prices synthroid levitra generic order viagra from us purchase accutane lasix discount cheapest cialis cheap cialis pill find discount viagra online lowest price for viagra accutane prices acomplia generic cheap cialis tablet synthroid pills viagra pharmacy online viagra overnight synthroid pharmacy viagra online stores buy discount viagra online levitra online certified viagra cheap viagra in canada cheapest propecia prices order viagra without prescription clomid sale price of viagra cialis cost lowest price synthroid purchase cialis buying generic viagra lasix pills generic accutane buy cheap soma online buy lasix cheap cialis online review purchase cialis overnight delivery soma for sale cheap viagra on internet lowest price cialis cheap viagra from uk buy generic lasix buy cheap lasix order levitra cialis without prescription cialis prices buy viagra no rx buy cialis no rx purchase zithromax online best price cialis cialis in uk buy discount cialis online propecia prescription cialis discount purchase lasix propecia sale order discount cialis viagra prices discount synthroid buy generic cialis soma online buy generic viagra online buy cialis from india cheap viagra pharmacy buy synthroid online online levitra order cheap viagra cost cialis cheapest cialis price cialis us acomplia without a prescription order cialis cheap generic zithromax cheap levitra cheap cialis without prescription cheapest viagra prices cheap cialis from canada zithromax pills zithromax generic buy viagra internet drug cialis online purchase compare viagra prices online buy cialis from us cialis tablets generic viagra online buy cheap viagra internet lasix prescription drug viagra accutane discount buying cialis online cheap soma order clomid buy generic acomplia cialis online without prescription price of levitra buy levitra online acomplia without prescription cialis rx buy propecia online buy cheap accutane price of synthroid synthroid prescription viagra online cheap synthroid online order propecia order synthroid online soma without a prescription viagra free delivery buy cialis without prescription purchase synthroid discount cialis without prescription buy viagra overnight delivery order acomplia online approved cialis pharmacy cialis uk order generic cialis buy propecia cheap cialis in bangkok clomid for sale zithromax pharmacy viagra online cheap order cheap cialis online pharmacy viagra buy cheapest cialis online order generic viagra cheap cialis overnight delivery buy cheap viagra find cheap cialis buy zithromax without prescription buy viagra on line tablet cialis purchase zithromax cialis in australia lowest price clomid overnight cialis cialis in us clomid without prescription cialis overnight delivery cheap lasix cheap synthroid cheapest lasix cheapest soma prices viagra cheap cheapest lasix prices find cialis on internet order viagra no prescription zithromax online compare cialis prices find cheap viagra online generic lasix discount propecia acomplia no prescription generic cialis online cheap viagra tablets order viagra buy soma cheap propecia for sale generic viagra cheap cheap propecia tablets cheap generic acomplia viagra bangkok discount viagra without prescription levitra prices cheapest accutane propecia online zithromax online cheap lasix sale where to buy lasix buy cheap synthroid online price of lasix price of acomplia find viagra no prescription required viagra online without prescription low cost cialis cheap zithromax propecia cheap acomplia online order cialis cheap online cheap cialis cialis bangkok lowest price for cialis cialis no online prescription cheap cialis pharmacy cialis canada buy accutane cheap cialis from uk viagra sales cialis from india order cialis without prescription order discount viagra order accutane find discount viagra order cialis no rx cialis prescription buy propecia without prescription cheap zithromax online cheap viagra pill buy cheap propecia purchase acomplia buying generic cialis cialis online pharmacy buy viagra online cheap buy cheap levitra online viagra for order cheap cialis in uk acomplia online generic clomid zithromax sale where to buy clomid buy viagra viagra without a prescription buy lasix online purchase propecia cheap cialis no rx viagra side effects order cheap cialis online cialis online cheap cialis drug online propecia generic cialis cheap cialis buy viagra no prescription required accutane pharmacy viagra discount buy soma online order viagra online propecia pharmacy accutane without a prescription levitra without prescription discount accutane cheapest viagra viagra no rx required buy cialis buy viagra cheap order no rx cialis cheapest cialis online purchase levitra cheapest zithromax lasix without a prescription zithromax order no rx viagra buy viagra lowest price cialis vendors cialis in malaysia cheapest generic cialis online cheap viagra buy discount cialis cialis from canada buy soma cialis malaysia levitra pharmacy synthroid no prescription cheap cialis tablets price of zithromax order cialis in canada discount soma order cialis overnight delivery soma cheap zithromax prescription order discount viagra online viagra from india propecia generic buy cheap cialis internet viagra buy viagra uk acomplia online cheap order acomplia cialis buy drug buy cheap lasix online levitra without a prescription cialis free delivery online acomplia where to buy cialis pharmacy viagra accutane online cheap cheapest generic viagra online purchase accutane online lowest price accutane buy viagra online generic soma lasix no prescription propecia without a prescription synthroid discount cheap generic accutane viagra sale viagra pill discount viagra no rx viagra free sample no rx viagra lasix online cheap order cheap viagra online viagra order lasix free viagra clomid pills buy cheap acomplia online propecia prices buy levitra without prescription price of accutane buy cheap viagra online lowest price zithromax soma find cialis find discount cialis order viagra no rx tablet viagra viagra buy online order synthroid viagra no online prescription soma prescription lowest price acomplia cheap viagra overnight delivery cheap acomplia discount viagra find viagra without prescription synthroid for sale acomplia prescription purchase synthroid online cialis information soma pills order lasix viagra no prescription lasix without prescription accutane pills purchase acomplia online zithromax online stores cheapest soma viagra cheapest price compare cialis prices online cheap viagra tablet order cialis online buy acomplia online cheap synthroid tablets viagra canada cialis no prescription viagra information price of propecia buy cialis generic order soma online order discount cialis online cheap generic lasix purchase viagra without prescription viagra vendors cialis medication order viagra overnight delivery viagra no rx overnight viagra cheap cialis online clomid prices cheap accutane buy viagra from india cialis tablet cheap viagra no rx viagra rx buy accutane online find no rx cialis buy generic cialis online cheap viagra without prescription cheapest propecia buy cheap propecia online levitra online cheap order viagra from canada accutane no prescription soma discount cheapest synthroid generic levitra cialis price online clomid generic cialis fda approved viagra purchase cialis no rx cialis without rx cheapest acomplia buy levitra pharmacy cialis accutane online stores soma online stores buy cialis from canada clomid generic propecia pills synthroid prices cheapest generic viagra buy cheap levitra buy cialis cheap buy cialis no prescription required viagra without prescription cheap generic soma accutane online buy viagra from canada find cialis online cialis no rx discount levitra buy cialis online cheap order cialis from us viagra in us buy cheap cialis online cialis for sale cheap price cialis cialis buy online order zithromax online fda approved cialis generic propecia viagra malaysia cheap cialis from usa buying cialis generic synthroid viagra medication propecia discount cheap generic cialis soma pharmacy levitra discount cheap generic propecia viagra for sale soma sale online zithromax acomplia cheap viagra from canada buy generic propecia viagra in bangkok buy cheap zithromax online cheap generic levitra cheap price viagra buy cheap cialis cheap cialis in canada buy generic soma cheap soma tablets viagra prescription lowest price levitra buy viagra from us cialis internet buy cheapest cialis buy viagra in us buying viagra cheapest viagra online viagra overnight delivery purchase soma clomid no prescription cialis pill cheap generic viagra levitra sale order viagra in canada viagra drug synthroid cheap order zithromax cialis cheap price buy cialis on internet cost of viagra clomid online

MySQLEste artículo puede sonar más bién a una llamada desesperada. Llevo unas semanas (por no decir un par de meses) liado con un proyecto que me consume más de lo que quisiera pero por respeto a la empresa no puedo desvelar casi nada. Y para colofón me aparece este problema que me está llevando de cabeza.

Resulta que tengo una query... sencilla en concepto, un par de joins cruzados... La construyo en local contra MySQL 4 y funciona perfectamente... y al subirla al servidor de producción con MySQL 5 simplemente me devuelve 0 rows. Estoy literalmente alucinando.

Explicación del escenario

Se trata de tres tablas con relación N:M, es decir, dos tablas principales y una que las une:

variables
---------
id (pk)
name

var_questions
-------------
id (pk)
id_variable (fk)
id_language (fk)
question

languages
----------
id (pk)
name
enabled

La tabla de variables contiene todas las variables registradas en el programa. La tabla languages contiene todos los idiomas disponibles en el programa. La tabla var_questions relaciona variables con languages y presenta el campo question que viene a ser el texto de la variable en el idioma determinado, es decir, para cada variable e idioma debe haber un texto.

Entonces yo necesito una query que me saque las inconsistencias (no las coincidencias), porque se trata de tablas MyISAM y en el proceso de desarrollo se puede haber creado un idioma sin haber generado ningún texto para él y para todas las variables. Mi query debe encontrar "lo que queda suelto".

La query

Usando la lógica (la mía, claro...) pensé: teniendo la lista de variables y la lista de idiomas, lo que debe presentar inconsistencias es la tabla intermedia. Entonces, podría hacer una query enlazando las variables con var_questions con un left join i la última con languages con un right join, para encontrar los nulls en la tabla intermedia var_questions. Luego le digo en el where que sólo quiero los nulls et violà.

SQL:
SELECT
  VARIABLES.name            AS var_name,
  VARIABLES.id        AS var_id,
  var_questions.question    AS question,
  languages.name            AS lang
FROM
  VARIABLES
    LEFT JOIN var_questions ON VARIABLES.id = var_questions.id_variable
      RIGHT JOIN languages ON var_questions.id_language = languages.id
WHERE
    var_questions.question IS NULL
AND languages.enabled = 1

La ejecuto en MySQL 4 y perfecto. Me saca justamente la información que necesito. Subo la query a producción, con un servidor MySQL 5 y me devuelve (con los mismos datos) 0 rows. Y justo ahí empieza mi odisea.

Investigando

La verdad es que poco más puedo investigar a parte de lo que haríamos todos: Googlear mucho, buscar problemas de compatibilidad, buscar documentación de JOINs, preguntar a cracks en el tema, dejar mensajes en foros, ...

Las versiones con las que juego son, en local, un MySQL 4.1.22-community-nt sobre Windows Vista, y en producción un MySQL 5.0.24a sobre Linux 2.6.9-023stab046.2-enterprise (Red Hat 3.4.5-2).

Durante las pruebas he encontrado una query que parece devolver los mismos resultados, pero no me gusta por el simple hecho que usa una CROSS JOIN que no podría explicar exactamente qué hace, pero parece hacer una producto cartesiano de las tablas enlazadas y no acepta un ON:

SQL:
SELECT
  VARIABLES.name            AS var_name,
  var_questions.question    AS question,
  languages.name            AS lang
FROM
  languages
    CROSS JOIN VARIABLES
      LEFT JOIN var_questions ON var_questions.id_language = languages.id
WHERE
    var_questions.question IS NULL
AND languages.enabled = 1

Cómo probar?

Tengo unos datos preparados por si alguien quiere hacer algunas pruebas (que serán agradecidas profundamente):

SQL:
CREATE TABLE `variables` (
  `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
  `name` varchar(100) collate latin1_spanish_ci NOT NULL DEFAULT '',
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_spanish_ci;

CREATE TABLE `languages` (
  `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
  `name` varchar(10) collate latin1_spanish_ci NOT NULL DEFAULT '',
  `enabled` tinyint(1) NOT NULL DEFAULT '0',
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_spanish_ci;

CREATE TABLE `var_questions` (
  `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
  `id_variable` int(11) UNSIGNED NOT NULL DEFAULT '0',
  `id_language` int(11) UNSIGNED NOT NULL DEFAULT '0',
  `question` text collate latin1_spanish_ci,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=163 DEFAULT CHARSET=latin1 COLLATE=latin1_spanish_ci;

INSERT INTO `languages` (`id`, `name`, `enabled`) VALUES (2, 'es', 1);
INSERT INTO `languages` (`id`, `name`, `enabled`) VALUES (4, 'ca', 1);
INSERT INTO `languages` (`id`, `name`, `enabled`) VALUES (5, 'en', 0);

INSERT INTO `variables` (`id`, `name`) VALUES (56, 'var_1');
INSERT INTO `variables` (`id`, `name`) VALUES (60, 'var_2');
INSERT INTO `variables` (`id`, `name`) VALUES (61, 'var_3');

INSERT INTO `var_questions` (`id`, `id_variable`, `id_language`, `question`) VALUES (157, 56, 2, 'Variable 1');
INSERT INTO `var_questions` (`id`, `id_variable`, `id_language`, `question`) VALUES (158, 60, 2, 'Variable 2');
INSERT INTO `var_questions` (`id`, `id_variable`, `id_language`, `question`) VALUES (159, 61, 2, 'Variable 3');

El resultado correcto debería ser el siguiente:

var_name var_id question lang
var_1 56 null ca
var_2 60 null ca
var_3 61 null ca

Colofón

Vale. No soy capaz de encontrar el problema. Será un problema de algún bug en la versión que uso para producción? Está mal planteada la query? A alguien se le ocurre algo?

Una cervecita para quien dé con la solución ;)

Salu10

Tags: , ,
 Enviar a Fresqui

Leer los Comentarios

[ # 19625 ] Comment desde franci [11 de Abril de 2008, 04:08]

Usar un valor null provocado por la inexistencia de tuplas en un left join o right join no creo que sea muy aconsejable (excepto si se utiliza desde otra sentencia que usa el resultado como tabla. Desconozco como sería en MySQL pero en derby, SQLServer y varios más podría ser así:

SELECT
V.name var_name,
V.id var_id,
‘null’ question,
L.name lang
FROM
VARIABLES V, languages L
WHERE
L.enabled = 1 and
not exists
(
select *
from
var_questions VQ
where
VQ.id_variable = V.id and
VQ.id_language = L.id and
VQ.question IS not NULL
)

al menos en derby (es lo que tengo en casa) me da el resultado que pides.

Por cierto ¿Me cambias la cervecita por un café o una horchata? :-)

[ # 19626 ] Comment desde Jurguen [11 de Abril de 2008, 04:38]

No es problema de Mysql o del Join, es solo que no vas a poder obtener ese tipo de resultado, realizando left o right join a menos que utilizes cross joins ¿y no veo el problema en usarlo?

Te envio una consulta que retorna el resultado que deseas:

select variables.name, variables.id, NULL as question, languages.name from variables,languages
where languages.id not in (select id_language from var_questions)
and languages.enabled=1

Es obvio que el campo question este en null, pero no se porque deseas mostrarlo.

Espero te sirva, nos leemos.

[ # 19627 ] Comment desde Chema [11 de Abril de 2008, 04:56]

En una mysql 5.0.54 (en linux gentoo con 2.6.23), el resultado que tu comentas resulta igual. A ver si te sirve de algo.

Un saludo,

[ # 19628 ] Comment desde Chema [11 de Abril de 2008, 04:59]

Pero ojo, no me devuelve 0 rows, sino mas bien esto:

var_name var_id question lang
NULL NULL NULL ca

[ # 19629 ] Comment desde Bellz [11 de Abril de 2008, 05:20]

He probado con un MySQL 5.051a y me retorna una fila con las columnas con valor nulo, exceptuando languages.name.

El resultado que esperas

var_name var_id question lang
var_1 56 null ca
var_2 60 null ca
var_3 61 null ca

no se puede dar nunca, al menos en esa forma.

El left join de var_questions retorna las filas coincidentes por identificador de variable y te devolverá las columnas de la selección correctamente. En cuanto aplicas el right join con languages te devolverá el lenguaje para las variables resultado del left join anterior y una fila (solo una) por lenguaje no coincidente y exceptuando los valores de languages el resto de columnas de esa fila tendrán valor nulo, por ejemplo

SELECT *
FROM variables
left JOIN var_questions ON (variables.id = var_questions.id_variable)
right JOIN languages ON (languages.id=var_questions.id_language)

retornará

id|name|id|id_variable|id_language|question|id|name|enabled
56|var_1|157|56|2|Variable 1|2|es|1
60|var_2|158|60|2|Variable 2|2|es|1
61|var_3|159|61|2|Variable 3|2|es|1
\N|\N|\N|\N|\N|\N|4|ca|1
\N|\N|\N|\N|\N|\N|5|en|0

Creo que el problema no es MySQL 5 sino MySQL 4, que no optimiza los resultados de los JOIN y aplica el último join a cada fila de resultado del join anterior, por ejemplo, la misma query anterior en un MySQL 4 produce éste resultado

id|name|id|id_variable|id_language|question|id|name|enabled
56|var_1|157|56|2|Variable 1|2|es|1
60|var_2|158|60|2|Variable 2|2|es|1
61|var_3|159|61|2|Variable 3|2|es|1
56|var_1|\N|\N|\N|\N|4|ca|1
60|var_2|\N|\N|\N|\N|4|ca|1
61|var_3|\N|\N|\N|\N|4|ca|1
56|var_1|\N|\N|\N|\N|5|en|0
60|var_2|\N|\N|\N|\N|5|en|0
61|var_3|\N|\N|\N|\N|5|en|0

Puede que esta query te sirva

SELECT variables.id, variables.name, languages.name FROM variables, var_questions, languages
where not languages.id = var_questions.id_language
and languages.enabled = 1
group by variables.id, languages.id order by variables.id

Un saludo.

[ # 19632 ] Comment desde Patxi Echarte [11 de Abril de 2008, 08:03]

Una forma sencilla de hacerlo es con consultas anidadas:

SELECT v.*, l.name
FROM variables AS v, languages AS l
WHERE l.enabled=1 AND v.id NOT
IN (
SELECT id_variable
FROM var_questions
WHERE id_language = l.id
)

[ # 19633 ] Comment desde Patxi Echarte [11 de Abril de 2008, 08:18]

Otra opción es tal como dices utilizando un join normal:

SELECT v.*, l.name
FROM
variables AS v CROSS JOIN languages AS l
LEFT JOIN var_questions AS vq ON v.id = vq.id_variable
AND vq.id_language=l.id
WHERE l.enabled=1 AND vq.id IS NULL

El cross join tal como dices se corresponde con el producto cartesiano de las tablas, (el join básico) en este caso de languages y variables. Esto produce que se obtengan todas las combinaciones de variables y lenguajes existentes. A partir de esto es suficiente con utilizar un left join para buscar los elementos que falten.

[ # 19636 ] Comment desde Biel Frontera [11 de Abril de 2008, 09:16]

Hola!
A mi me funciona la select en la versión 5.0.30-Debian (después de cambiar VARIABLES por variables).

De todas maneras, podrías plantear la select de otra manera (no sé si es más pesada o no… pero también tiene que funcionar). Puedes hacer una lectura de todas las parejas lenguaje-variable que no encuentre ningún registro en la tabla var_questions (con un count).

Sería:
SELECT
variables.name AS var_name,
languages.name AS lang
FROM languages, variables
WHERE
languages.enabled =1
AND (
SELECT count( 1 )
FROM var_questions
WHERE
var_questions.id_language = languages.id
AND var_questions.id_variable = variables.id
) = 0

[ # 19763 ] Comment desde Xavi [14 de Abril de 2008, 08:43]

@Franci, Jurguen, Patxi y Biel: Se me olvidó de decir que quería no utilizar subquerys… Hace tiempo hicimos unas pruebas con un amigo y descubrimos que la subconsulta se re-ejecuta a cada iteración de la consulta principal, con lo que se vuelve mucho mucho más pesada. De todas formas, gracias ;) Y no es que desee mostrar el campo NULL, es simplemente para ver que realmente es null (mientras desarrollo la query).

@Chema: No entiendo ése resultado… De acuerdo que faltan todas las variables con el lenguage “ca”, pero deberían salir con su nombre… juer

@Bellz: Tienes mi cerveza. ;) Por un lado te diré que mi query si que me funciona en MySQL 4. Entiendo tu explicación y entiendo también que el fallo realmente es de MySQL 4 en aplicar el right join a todos los resultados del left join (aunque podría pensarse en otros casos que éso pudiera ser correcto). He probado tu query en MySQL y no ha funcionado. En cambio, en MySQL 5 ha funcionado de forma esperada y me da los resultados correctos. Hasta me da vergüenza ver lo simple que és, y yo liándome con cross joins… Gracias majo!

@Patxi: gracias por la explicación del CROSS JOIN

A todos, gracias por responder. Da gusto ver que aún hay gente dispuesta a echar una mano.

Salu10!

[ # 19781 ] Comment desde Bellz [14 de Abril de 2008, 02:09]

De nada Xavi ;)

Gracias por la cerve :)

Escribe un Comentario





Estadísticas