Foros del Web » Programando para Internet » PHP »

problema en la insercion de la base de datos y un warning

Estas en el tema de problema en la insercion de la base de datos y un warning en el foro de PHP en Foros del Web. hola le spido el favor me ayuden a mirar por que me sale este error Warning: mysql_query(): supplied argument is not a valid MySQL-Link resource ...
  #1 (permalink)  
Antiguo 13/04/2009, 11:15
 
Fecha de Ingreso: julio-2008
Ubicación: Bogota
Mensajes: 59
Antigüedad: 16 años, 4 meses
Puntos: 1
Pregunta problema en la insercion de la base de datos y un warning

hola le spido el favor me ayuden a mirar por que me sale este error

Warning: mysql_query(): supplied argument is not a valid MySQL-Link resource in C:\wamp\www\centro_conciliacion\insertar_radicacio n.php on line 6

les dejo mi archivo de conexion

Código PHP:
<?php
// conectar al servidor de base de datos
class conexion{
    public 
$linkbd;
    function 
conectar(){
        
$this->linkbd=mysql_connect("localhost","root","root");
        
mysql_select_db("centro_conciliacion",$this->linkbd);
    }

$conexion=new conexion();
$link=$conexion->linkbd;

?>
y el archivo que realiza la transaccion
Código PHP:
<?php
include_once('conexion_bd.php');

$query="INSERT INTO radicador_cc (fecha_recibido,nombre_solicitante,nombre_solicitado,observaciones) VALUES ('".$_REQUEST['fecha_recibido']."','".$_REQUEST['nombre_solicitante']."','".$_REQUEST['nombre_solicitado']."','".$_REQUEST['observaciones']."')";
//echo $query;
$execute=mysql_query($query,$link);

?>
espero me puedan ayudar
  #2 (permalink)  
Antiguo 13/04/2009, 11:19
Avatar de ACX_POISON  
Fecha de Ingreso: abril-2008
Ubicación: Talca-Chile
Mensajes: 750
Antigüedad: 16 años, 7 meses
Puntos: 7
Respuesta: problema en la insercion de la base de datos y un warning

pon

mysql_query($query,$link)or die (mysql_error());
__________________
Me junto con los que Saben, Queriendo Saber.
  #3 (permalink)  
Antiguo 13/04/2009, 11:26
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 16 años, 3 meses
Puntos: 2237
Respuesta: problema en la insercion de la base de datos y un warning

Intenta:

$execute=mysql_query($query,$conexion->linkbd);

De cualquier manera, me parece un poco perdida de tiempo crear una clase que unicamente realiza la conexion a base de datos.
__________________
- León, Guanajuato
- GV-Foto
  #4 (permalink)  
Antiguo 13/04/2009, 11:33
 
Fecha de Ingreso: julio-2008
Ubicación: Bogota
Mensajes: 59
Antigüedad: 16 años, 4 meses
Puntos: 1
Respuesta: problema en la insercion de la base de datos y un warning

mira puse las dos opciones y me sigue saliendo el mismo error

y pues Triby hasta ahora estoy comenzando a trabajar y a entender como funciona las conexion por clases y esas cosas

te agradeceria si me dijieras donde me puedo documentar mejor y asi poder realizar una clase que me permita trabajar todas las funciones como insertar consultar actualizar etcc


gracias por las respuestas
  #5 (permalink)  
Antiguo 13/04/2009, 12:24
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 16 años, 3 meses
Puntos: 2237
Respuesta: problema en la insercion de la base de datos y un warning

Ejemplo de una clase sencilla para mysql, tomada de PunBB:

Código php:
Ver original
  1. <?php
  2. /***********************************************************************
  3.  
  4.   Copyright (C) 2002-2005  Rickard Andersson ([email protected])
  5.  
  6.   This file is part of PunBB.
  7.  
  8.   PunBB is free software; you can redistribute it and/or modify it
  9.   under the terms of the GNU General Public License as published
  10.   by the Free Software Foundation; either version 2 of the License,
  11.   or (at your option) any later version.
  12.  
  13.   PunBB is distributed in the hope that it will be useful, but
  14.   WITHOUT ANY WARRANTY; without even the implied warranty of
  15.   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16.   GNU General Public License for more details.
  17.  
  18.   You should have received a copy of the GNU General Public License
  19.   along with this program; if not, write to the Free Software
  20.   Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  21.   MA  02111-1307  USA
  22.  
  23. ************************************************************************/
  24. if(!defined('PUN')) {
  25.     header('HTTP/1.0 403 Forbidden');
  26.     die('You don\'t have permission to browse this directory or open the file.');
  27. }
  28.  
  29. // Make sure we have built in support for MySQL
  30. if (!function_exists('mysql_connect'))
  31.     exit('This PHP environment doesn\'t have MySQL support built in. MySQL support is required if you want to use a MySQL database to run this forum. Consult the PHP documentation for further assistance.');
  32.  
  33. class DBLayer {
  34.     var $prefix;
  35.     var $link_id;
  36.     var $query_result;
  37.     var $saved_queries = array();
  38.     var $show_queries = false;
  39.     var $num_queries = 0;
  40.  
  41.     function DBLayer($db_host, $db_username, $db_password, $db_name, $db_prefix, $p_connect, $showq = false) {
  42.         $this->prefix = $db_prefix;
  43.         $this->show_queries = $showq;
  44.         if ($p_connect)
  45.             $this->link_id = @mysql_pconnect($db_host, $db_username, $db_password);
  46.         else
  47.             $this->link_id = @mysql_connect($db_host, $db_username, $db_password);
  48.  
  49.         if ($this->link_id) {
  50.             if (@mysql_select_db($db_name, $this->link_id))
  51.                 return $this->link_id;
  52.             error('Unable to select database. MySQL reported: '.mysql_error(), __FILE__, __LINE__);
  53.         }
  54.         error('Unable to connect to MySQL server. MySQL reported: '.mysql_error(), __FILE__, __LINE__);
  55.     }
  56.  
  57.     function start_transaction() {
  58.         return;
  59.     }
  60.  
  61.     function end_transaction()  {
  62.         return;
  63.     }
  64.  
  65.     function query($sql, $check_empty = false, $unbuffered = false) {
  66.         if ($this->show_queries)
  67.             $q_start = microtime();
  68.  
  69.         if ($unbuffered)
  70.             $this->query_result = @mysql_unbuffered_query($sql, $this->link_id);
  71.         else
  72.             $this->query_result = @mysql_query($sql, $this->link_id);
  73.         if ($this->query_result) {
  74.             if ($this->show_queries)
  75.                 $this->saved_queries[] = array($sql, sprintf('%.5f', microtime() - $q_start));
  76.             ++$this->num_queries;
  77.             // If check_empty = true and there were no rows loaded, return false
  78.             if($check_empty && $this->num_rows($this->query_result) < 1)
  79.                 return false;
  80.             return $this->query_result;
  81.         }
  82.         if ($this->show_queries)
  83.             $this->saved_queries[] = array($sql, 0);
  84.         return false;
  85.     }
  86.  
  87.     function result($query_id = 0, $row = 0) {
  88.         return ($query_id) ? @mysql_result($query_id, $row) : false;
  89.     }
  90.  
  91.     function fetch_assoc($query_id = 0) {
  92.         return ($query_id) ? @mysql_fetch_assoc($query_id) : false;
  93.     }
  94.  
  95.     function fetch_row($query_id = 0) {
  96.         return ($query_id) ? @mysql_fetch_row($query_id) : false;
  97.     }
  98.  
  99.     function num_rows($query_id = 0) {
  100.         return ($query_id) ? @mysql_num_rows($query_id) : false;
  101.     }
  102.  
  103.     function affected_rows() {
  104.         return ($this->link_id) ? @mysql_affected_rows($this->link_id) : false;
  105.     }
  106.  
  107.     function insert_id() {
  108.         return ($this->link_id) ? @mysql_insert_id($this->link_id) : false;
  109.     }
  110.  
  111.     function get_num_queries() {
  112.         return $this->num_queries;
  113.     }
  114.  
  115.     function get_saved_queries() {
  116.         return $this->saved_queries;
  117.     }
  118.  
  119.     function free_result($query_id = false) {
  120.         return ($query_id) ? @mysql_free_result($query_id) : false;
  121.     }
  122.  
  123.     function escape($str) {
  124.         if (is_array($str))
  125.             return '';
  126.         if (function_exists('mysql_real_escape_string'))
  127.             $str = mysql_real_escape_string($str, $this->link_id);
  128.         else
  129.             $str = mysql_escape_string($str);
  130.         return $str;
  131.     }
  132.  
  133.     function error() {
  134.         $result['error_sql'] = @current(@end($this->saved_queries));
  135.         $result['error_no'] = @mysql_errno($this->link_id);
  136.         $result['error_msg'] = @mysql_error($this->link_id);
  137.         return $result;
  138.     }
  139.  
  140.     function close() {
  141.         if ($this->link_id)     {
  142.             if ($this->query_result)
  143.                 @mysql_free_result($this->query_result);
  144.             return @mysql_close($this->link_id);
  145.         }
  146.         return false;
  147.     }
  148. }
__________________
- León, Guanajuato
- GV-Foto
  #6 (permalink)  
Antiguo 13/04/2009, 12:26
Avatar de argy  
Fecha de Ingreso: octubre-2007
Ubicación: Longitud 75º Latitud 18º Sur
Mensajes: 614
Antigüedad: 17 años
Puntos: 18
Respuesta: problema en la insercion de la base de datos y un warning

mm??? no entiendo lo que intentas hacer más allá de que si te es útil o no la clase
Código :
Ver original
  1. <?php
  2. // conectar al servidor de base de datos
  3. class conexion{
  4.     public $linkbd;
  5.     function conectar(){
  6.         $this->linkbd=mysql_connect("localhost","root","root");
  7.         mysql_select_db("centro_conciliacion",$this->linkbd);
  8.     }
  9. }
  10. $conexion=new conexion();
  11. $link=$conexion->linkbd;
  12.  
  13. ?>
primero que nada debes de declarar como privado el atributo(lee teoria de POO).

tu método(la función) debe de retornar algo, en este caso la conexión con return.
veo que instancias la clase pero no le das ninguna utilidad al método XD, entonces para que está ahí perdiendo el tiempo jajaja.

por lo que al final quedaría así
Código :
Ver original
  1. <?php
  2. // conectar al servidor de base de datos
  3. class conexion{
  4.     private $linkbd;
  5.     public function conectar(){
  6.         $this->linkbd=mysql_connect("localhost","root","root");
  7.         mysql_select_db("centro_conciliacion",$this->linkbd);
  8. return $this->linkbd;
  9.     }
  10. }
  11. $conexion=new conexion();
  12. $link=$conexion->conectar();
  13.  
  14. ?>
claro que de hecho tienes que mejorar esa clase, por ejemplo que lea desde un archivo de configuración los datos de conexión a BD.

suerte.
__________________
Software libre para un mundo libre.

Eventualmente en el foro.
  #7 (permalink)  
Antiguo 13/04/2009, 12:44
 
Fecha de Ingreso: febrero-2009
Ubicación: cancun!
Mensajes: 898
Antigüedad: 15 años, 9 meses
Puntos: 15
Respuesta: problema en la insercion de la base de datos y un warning

mysql_query("INSERT INTO radicador_cc (fecha_recibido,nombre_solicitante,nombre_solicita do,observaciones) VALUES ('".$_REQUEST['fecha_recibido']."','".$_REQUEST['nombre_solicitante']."','".$_REQUEST['nombre_solicitado']."','".$_REQUEST['observaciones']."');

y si lo pones directamente
??
saludines!
__________________
WHERE IS MY BLUE SUNNY SKY??
pd: todos los karmas son bienvenidos :D
  #8 (permalink)  
Antiguo 13/04/2009, 12:55
 
Fecha de Ingreso: julio-2008
Ubicación: Bogota
Mensajes: 59
Antigüedad: 16 años, 4 meses
Puntos: 1
Respuesta: problema en la insercion de la base de datos y un warning

les agradesco a todos por su colaboracion
mil gracias tendre muy presente todas sus observaciones y estudiare mas POO y espero poder conseguir experiencia para develoverle un poquito a esta gran comunidad que me a ayudado tanto
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 14:09.