Foros del Web » Programando para Internet » PHP »

Php/mssql

Estas en el tema de Php/mssql en el foro de PHP en Foros del Web. Hola a todos Tengo un pequeño problema al realizar consultas que atacan a BBDD de sql server. Tengo una aplicación en php que ejecuta consultas ...
  #1 (permalink)  
Antiguo 24/10/2008, 09:21
 
Fecha de Ingreso: abril-2006
Mensajes: 76
Antigüedad: 18 años
Puntos: 0
Exclamación Php/mssql

Hola a todos

Tengo un pequeño problema al realizar consultas que atacan a BBDD de sql server. Tengo una aplicación en php que ejecuta consultas sql (creada por el usuario) y la lanza a varias BBDD de sql server. El problema es cuando trabajo con consultas que tengan fechas que no me retorna ningún registro. Algo pasa siempre que filtro por fechas.....

Una consulta puede ser:

select *
from clientes a
where exists ( select sum(importe)
from faclin b
inner join faclinprod c on b.faclincod = c.faclincod and c.fecha between '01/01/2007' and '31/12/2008'
where b.cliente = a.cliente and b.grupcli = a.grupcli
having sum(importe)>0 )
and a.grupcli = 'AGEN'

Esta consulta la he realizado con el analizador de consultas sql y retorna resultados. Pero al copiar y pegar a la aplicación en php no funciona. ¿Por qué? no se, pero si realizamos la misma consulta sin filtro de fechas funciona. He comprobado con el analizador de sql que la consulta la lanza al servidor sql tal i como la he escrito por lo que php tocaria recibir resultados pero el resource #id en php no contiene ninguno?!?!?

Alguien sabe algo del tratamiento de fechas en PHP/MSSQL?


PD: La misma consulta sin fechas funciona (y no es porque la consulta no devuelva resultados ojo)

select *
from clientes a
where exists ( select sum(importe)
from faclin b
inner join faclinprod c on b.faclincod = c.faclincod
where b.cliente = a.cliente and b.grupcli = a.grupcli
having sum(importe)>0 )
and a.grupcli = 'AGEN'


Saludos.
  #2 (permalink)  
Antiguo 24/10/2008, 09:23
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: Php/mssql

Hola yartax,

Muy raro que te funcione de la forma que indicas, ya que a mi último conocimiento SQL Server requiere que pases las fechas entre ## en lugar de comillas.

Saludos.
  #3 (permalink)  
Antiguo 24/10/2008, 09:33
Avatar de Carxl
Colaborador
 
Fecha de Ingreso: agosto-2006
Ubicación: Bogotá
Mensajes: 2.993
Antigüedad: 17 años, 8 meses
Puntos: 70
Respuesta: Php/mssql

Hola GatorV...

Pues las veces que he manejado sqlserver, el tratamiento de las fechas las hago con ''... nunca con #

Cosas que pasan...
__________________
Hay 10 tipos de personas, los que entienden binario y los que no. (Anónimo)
www.programandoweb.com
  #4 (permalink)  
Antiguo 24/10/2008, 09:43
 
Fecha de Ingreso: abril-2006
Mensajes: 76
Antigüedad: 18 años
Puntos: 0
Respuesta: Php/mssql

Hola GatorV

Lo de poner ## me suena a ms access!!

Saludos
Yartax.
  #5 (permalink)  
Antiguo 24/10/2008, 09:52
Avatar de vika  
Fecha de Ingreso: julio-2008
Mensajes: 13
Antigüedad: 15 años, 9 meses
Puntos: 0
Respuesta: Php/mssql

Hola
Deberias de ver como te coloca la fecha en la base de datos, por que te las puede colocar con un formato diferente al cual tu estas haciendo la comparacion. Tal vez en lugar de diagonales "/" coloca in guion "-", o el formato es mes, dia y año
  #6 (permalink)  
Antiguo 24/10/2008, 10:04
Avatar de masterojitos  
Fecha de Ingreso: julio-2008
Ubicación: Lima Callao Chucuito
Mensajes: 1.931
Antigüedad: 15 años, 8 meses
Puntos: 105
Respuesta: Php/mssql

y prueba asi:

select *
from clientes a
where exists ( select sum(importe)
from faclin b
inner join faclinprod c on b.faclincod = c.faclincod where c.fecha between '01/01/2007' and '31/12/2008' and b.cliente = a.cliente and b.grupcli = a.grupcli
having sum(importe)>0 )
and a.grupcli = 'AGEN'
__________________
Atte. MasterOjitos :ojotes:
Todo sobre Programación Web
Las ultimas tendencias en Efectos y Recursos Web: MasterOjitos Blog
  #7 (permalink)  
Antiguo 24/10/2008, 10:05
 
Fecha de Ingreso: abril-2006
Mensajes: 76
Antigüedad: 18 años
Puntos: 0
Respuesta: Php/mssql

Hola vika

Como he comentado, con el analizador de trazas de sql veo como la consulta que lanza el servidor php contra sql utiliza el mismo texto exacto que he introducido por web. A demas veo que el servidor sql procesa la petición correctamente con sus numeros #reads #writes.

Supongo que realizando la consulta con convert(blablalba) en sql pudiera ir bien, pero si quiero hacer una consulta rapidita y filtrar por fecha no voy a pedir por web que me pongan la consulta de tal forma que php la pueda procesar bien....tiene que haber algun tema con la gestión de fechas en mssql y no sé que puede ser.

Lo bien que me van en Firebird.....hay que ver.

Saludos
Yartax
  #8 (permalink)  
Antiguo 24/10/2008, 10:07
Avatar de masterojitos  
Fecha de Ingreso: julio-2008
Ubicación: Lima Callao Chucuito
Mensajes: 1.931
Antigüedad: 15 años, 8 meses
Puntos: 105
Respuesta: Php/mssql

Cita:
Iniciado por masterojitos Ver Mensaje
y prueba asi:

select *
from clientes a
where exists ( select sum(importe)
from faclin b
inner join faclinprod c on b.faclincod = c.faclincod where c.fecha between '01/01/2007' and '31/12/2008' and b.cliente = a.cliente and b.grupcli = a.grupcli
having sum(importe)>0 )
and a.grupcli = 'AGEN'
__________________
Atte. MasterOjitos :ojotes:
Todo sobre Programación Web
Las ultimas tendencias en Efectos y Recursos Web: MasterOjitos Blog
  #9 (permalink)  
Antiguo 24/10/2008, 10:07
 
Fecha de Ingreso: abril-2006
Mensajes: 76
Antigüedad: 18 años
Puntos: 0
Respuesta: Php/mssql

Nada igual. Además no veo que cambio has hecho?!?! Tabuladores quizas?

Repido que la misma consulta copiar y pegar (sin el filtro por fechas funciona)

Saludos
Yartax.
  #10 (permalink)  
Antiguo 24/10/2008, 10:09
Avatar de masterojitos  
Fecha de Ingreso: julio-2008
Ubicación: Lima Callao Chucuito
Mensajes: 1.931
Antigüedad: 15 años, 8 meses
Puntos: 105
Respuesta: Php/mssql

amiga si he cambiado:

el between de las fechas lo puse dentro de la clausura where.

bueno, es mi aporte.

suerte.
__________________
Atte. MasterOjitos :ojotes:
Todo sobre Programación Web
Las ultimas tendencias en Efectos y Recursos Web: MasterOjitos Blog
  #11 (permalink)  
Antiguo 02/01/2009, 08:08
 
Fecha de Ingreso: diciembre-2008
Mensajes: 7
Antigüedad: 15 años, 4 meses
Puntos: 1
Respuesta: Php/mssql

tengo el mismo problema yartax! pusite solucionarlo?
yo intente con una funcion para cambiar el formato:

function cambiaf_a_mssql($fecha){
ereg( "([0-9]{1,2})/([0-9]{1,2})/([0-9]{2,4})", $fecha, $mifecha);
$lafecha=$mifecha[3].$mifecha[2].$mifecha[1];
return $lafecha;
}

espero noticias! gracias
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 15:18.