Foros del Web » Programando para Internet » PHP »

Conectar a mysql y seleccionar db con una funcion desde otra funcion?

Estas en el tema de Conectar a mysql y seleccionar db con una funcion desde otra funcion? en el foro de PHP en Foros del Web. Estoy haciendo algo "organizado".. con un config.php con los datos de la db, un conexion.php donde esta la funcion con que se conecta y seleccion ...
  #1 (permalink)  
Antiguo 27/02/2010, 20:59
Avatar de Carlmycol  
Fecha de Ingreso: diciembre-2007
Ubicación: Los Teques, Venezuela
Mensajes: 240
Antigüedad: 16 años, 4 meses
Puntos: 3
Conectar a mysql y seleccionar db con una funcion desde otra funcion?

Estoy haciendo algo "organizado".. con un config.php con los datos de la db, un conexion.php donde esta la funcion con que se conecta y seleccion la db, y estoy haciendo otra funcion en otro archivo que usa la funcion anterior para hacer una consulta..

Pero no selecciona la DB, porque? :S
Mis Codigos
Config.php
Código PHP:
<?
$host
=="localhost";
$user="root";
$password="pass";
$db="db";
?>
Conexion.php
Código PHP:
<?


function conectar()
{
    
$conexion=@mysql_connect($host$user$password);
    if (!
$conexion) {
        
printf("Error al Conectar con la Base de Datos");
        exit();
    }
    
mysql_select_db($db$conexion);
    return 
$conexion;

}
?>
Y el archivo con la funcion que utiliza conectar()
Código PHP:
<?
function get_lastPost_content($limit) {
    
$link=conectar();
    
$consulta="SELECT * FROM articulos ORDER BY id DESC LIMIT $limit";
    
$result=mysql_query($consulta$link) or die (mysql_error());
    
$i=0;
    while (
$row=mysql_fetch_array($result))
    {
        
//$contenidos[$i]=$row['contenido'];
        //$i++;
        
echo $row['contenido'];
    }
    
//return array($contenidos);
    
}
?>
Todo esto para un Index.php en el que solo halla que llamar a la funcion anterior sin tener que conectar ni nada.. :/

Algo asi como esto
Código PHP:
<?
require('./config.php');
require(
'./Sources/Conexion.php');

require(
'./Sources/Funciones.Post.php');



get_lastPost_content(5);


?>
Creen que tenga que convertir la funcion conectar() en un objeto?

Saludos, gracias de antemano
  #2 (permalink)  
Antiguo 27/02/2010, 21:06
 
Fecha de Ingreso: diciembre-2009
Ubicación: Barcelona
Mensajes: 8
Antigüedad: 14 años, 4 meses
Puntos: 0
Respuesta: Conectar a mysql y seleccionar db con una funcion desde otra funcion?

PAra qué este @

$conexion=@mysql_connect($host, $user, $password);

En teoria si connecta bien no tine que haber problemas, no hace falta esconder los errores no?

Supongo que te debe de saltar al if claro, te mostrará el error y se irá al exit.


Bueno, lo que realmente me da que pensar es, el codigo me parece bastante bien, no le veo errores, pero, la db se llama exactamente "db" ? si no te selecciona la base de datos tiene que ser una tonteria de estas de sintaxi o así..

Espero que te haya servido.
Saludos!
  #3 (permalink)  
Antiguo 27/02/2010, 21:45
Avatar de jackson666  
Fecha de Ingreso: noviembre-2009
Ubicación: Buenos Aires, Argentina
Mensajes: 1.971
Antigüedad: 14 años, 5 meses
Puntos: 65
Respuesta: Conectar a mysql y seleccionar db con una funcion desde otra funcion?

Código PHP:
<?
function conectar()
{
    
$conexion=@mysql_connect($host$user$password);
    if (!
$conexion) {
        
printf("Error al Conectar con la Base de Datos");
        exit();
    }
    
mysql_select_db($db$conexion);
    return 
$conexion;

}
?>
Y de donde sale la variable $db??? Porque si esta fuera del scope funcion, no es interpretada...

A lo sumo podrias hacer:

Código PHP:
<?
function conectar($db)
{
    
$conexion=@mysql_connect($host$user$password);
    if (!
$conexion) {
        
printf("Error al Conectar con la Base de Datos");
        exit();
    }
    
mysql_select_db($db$conexion);
    return 
$conexion;

}

# Ejemplo de uso
conectar('mi_base');
?>
Ah y un detalle mas, no es de buena practica tapar los errores con '@', podrias usar try{} y catch(){} en todo caso, o sino mas facil, usar mysql_error()...
Tambien acostumbrate a no usar '<?'. Usa '<?php'
__________________
HV Studio
Diseño y desarrollo web

Etiquetas: funcion, mysql, seleccionar
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 02:11.