Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP][MYSQL]pobieranie danych z bazy danych z @
Forum PHP.pl > Forum > Przedszkole
gonzo_yest_bosSKY
<?php
include('config.php');

if ($_POST['server'] == 'Server 1') {
$db_con = mysql_connect($db_s1_host, $db_s1_login, $db_s1_pass)
//or die('<META HTTP-EQUIV="Refresh" CONTENT="0; URL="http://localhost/aotest/index.php?err=1"> ');
or die('Nie można się połaczyć: ' . mysql_error());
$db_act = mysql_select_db($db_s1_dbase, $db_con)
or die('Nie można się połaczyć z baza: ' . mysql_error());
$db_re = mysql_query('SELECT `user` FROM `users` WHERE `mail` = '.$_POST['mail'])
or die('zapytanie: ' . mysql_error());
$rekord=mysql_fetch_assoc($db_re);
echo ($rekord["user"]);
mysql_close($db_con);
}


?>

pliki wysyłane z pliku index.php metoda post w pliku config.php mam ustawienia bazy danych login pass itd.


error: jaki otrzymuje to

testzapytanie: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '@wp.pl' at line 1

baza wyglada tak

-- phpMyAdmin SQL Dump
-- version 2.6.4-pl3
-- http://www.phpmyadmin.net
--
-- Host: localhłost
-- Czas wygenerowania: 15 Sty 2011, 04:12
-- Wersja serwera: 5.0.91
-- Wersja PHP: 5.2.6-1+lenny9
--
-- Baza danych: `aot`
--

-- --------------------------------------------------------

--
-- Struktura tabeli dla `users`
--

CREATE TABLE `users` (
`id` int(11) NOT NULL auto_increment,
`user` text collate utf8_unicode_ci NOT NULL,
`mail` text collate utf8_unicode_ci NOT NULL,
`pass` text collate utf8_unicode_ci NOT NULL,
`status` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=2 ;

--
-- Zrzut danych tabeli `users`
--

INSERT INTO `users` VALUES (1, 'g0nz0', 'gonzo_post@wp.pl', '8a1e6c67838f7a4e5c65c317e4894209', 0);
CuteOne
$db_re = mysql_query('SELECT `user` FROM `users` WHERE `mail` = '.$_POST['mail'])

podmień na

$db_re = mysql_query("SELECT `user` FROM `users` WHERE `mail` = '{$_POST['mail']}'")

zapytania wrzucaj w cudzysłów, stringi w apostrofy, tablice w klamry
gonzo_yest_bosSKY
ok pomogło nie ma błędu ale teraz inna kwestia

  1. $rekord=mysql_fetch_assoc($db_re);
  2. echo ($rekord["user"]);
  3. mysql_close($db_con);


powinno wywalic "g0nz0" a mam blank screen

EDIT: z @ poradziłem sobie przy pomocy ereg_replace
CuteOne
  1. <?php
  2. include('config.php');
  3.  
  4. if ($_POST['server'] == 'Server 1') {
  5. $db_con = mysql_connect($db_s1_host, $db_s1_login, $db_s1_pass)
  6. //or die('<META HTTP-EQUIV="Refresh" CONTENT="0; URL="http://localhost/aotest/index.php?err=1"> ');
  7. or die('Nie można się połaczyć: ' . mysql_error());
  8. $db_act = mysql_select_db($db_s1_dbase, $db_con)
  9. or die('Nie można się połaczyć z baza: ' . mysql_error());
  10.  
  11. $mail = $_POST['mail'];
  12. $db_re = mysql_query("SELECT `user` FROM `users` WHERE `mail` = '$mail'") or die('zapytanie: ' . mysql_error());
  13.  
  14. $rekord=mysql_fetch_assoc($db_re);
  15. echo ($rekord["user"]);
  16. mysql_close($db_con);
  17. }


I wywal ten ereg...
gonzo_yest_bosSKY
dobra poddaje sie nie wiedze bykafakt ze zmienna $_POST['mail'] po zamianie maila to teraz $usr_mail ale ciagle nie widze byka dało by rade łopatologicznie.

EDIT: wkleiłem kod działa Dzięki

EDI: A moge wiedzie gdzie był błąd?questionmark.gif (bo nie sztuka naklarmic glodnego sztuka dac mu wedke). Czemu zmienna POST powodowała bledy i o co chodziło z tym @wp.pl

UP TEMATU

poprosze o wyjaśnienie czemu to nie działało. W myśl zasady lepiej dac wedke niż rybe. Naprawde chce wiedzie co było błędem
CuteOne
@ jest hmmm tak jakby "znacznikiem" tak jak OR, WHERE, SELECT, DELETE. Nie dając adresu mail w apostrof mysql odczytał to jako znacznik a nie string
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.