Beiträge von palwal

    Ich habe mal eine Frage, seit dem ich in meinen Script zCMD includiert habe, gehen alle anderen Befehle nicht die in OnPlayerCommandText geschrieben sind, das sind ALLE Server Befehle. Es funktionieren seit dem nur die zCMD Befehle. Woran liegt es und wie behebe ich es?


    Liebe Grüße

    Hallo Brotfische,


    wie das Thread-Titel schon sagt, wird ein White-Screen angezeigt sobald die Function $this->_readCountyByPlace() mit aufgerufen wird.
    Das System ist die erste Version einer neuen GEO-API von mir.

    Kompletter Script:


    function input wird letztendlich dann in der Index-Datei ausgeführt.


    Sobald die function $this->_readCountyByPlace() in der input() auskommentiert wird, funktioniert alles einwandfrei. Ich kann mir den Fehler nicht erklären.
    Sofern ich mit die() or echo eine Ausgabe in _readCountyByPlace() erzwinge, wird trotzdem alles andere nicht angezeigt.


    Vielleicht habt ihr Fehlerbehebungslösungen die mir weiterhelfen....

    Deine Abfrage ist durchaus sinnvoll.
    Das macht aber wenig Unterschied.


    Da es auch klappen wird wenn @Sean_Caprez statt LIKE, ein = schreiben würde. Weil LIKE findet gern mehrere Accounts die sich vom Namen ähneln.

    Moin Brotfische,


    hätte nie gedacht das ich wegen einen Simplen LIKE-Befehl in einer Sackgasse stehen würde.
    Also ich habe eine Suche in Ajax konzeptiert.
    Ausgeführt wird die Methode company().


    Script:


    Problembeschreibung:
    Wenn man in der Suche etwas eingibt, gibt MySQL ALLE existierenden Datensätze in der Tabelle aus. Egal welches Zeichen man n der Suche schreibt. Auch Zeichen die in der Datenbank nicht vorhanden sind. Es macht kein Unterschied in welche Anordnung % ist. Es werden immer alle "Kunden" angezeigt.
    Laut MySQL was ich nochmal nachgesehen habe denke ich habe ich alles richtig gemacht oder hab ich einen Denkfehler?


    Liebe Grüße
    Patrick

    das ist nicht gefährlich, einfach nur Sinnlos von mir. Was ich nur zu testzwecken was anderen verwendet hatte.


    Ich hatte in meiner db.class.php
    es jetzt so:

    PHP
    try{
    			$this->synup = new \PDO($this->dsn, $this->user, $this->pass, $optionen);
    			$this->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
    			$this->setAttribute(\PDO::ATTR_EMULATE_PREPARES, false);
    			$this->setAttribute(\PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, true);
    		} catch(\PDOException $e)
    		{
    			$this->error = $e->getMessage();
    			die($e->getMessage());
    		}


    Allerdings funktioniert es immernoch nicht

    Sorry, total vergessen


    PHP
    [error] [client xx.xxx.xx.xxx] PHP Fatal error:  Uncaught exception 'PDOException' with message 'SQLSTATE[HY000]: General error: 2014 Cannot execute queries while other unbuffered queries are active.  Consider using PDOStatement::fetchAll().  Alternatively, if your code is only ever going to run against mysql, you may enable query buffering by setting the PDO::MYSQL_ATTR_USE_BUFFERED_QUERY attribute.' in /var/customers/webs/anzenjo/anzenjo.riows-hosting.net/cc/system/classes/db.class.php:60\nStack trace:\n#0 /var/customers/webs/anzenjo/anzenjo.riows-hosting.net/cc/system/classes/db.class.php(60): PDO->prepare('SELECT * FROM `...')\n#1 /var/customers/webs/anzenjo/anzenjo.riows-hosting.net/cc/system/classes/sessions.class.php(55): Database->Query('SELECT * FROM `...')\n#2 /var/customers/webs/anzenjo/anzenjo.riows-hosting.net/cc/system/classes/PageHandle.class.php(71): Session->UserFetch(37)\n#3 /var/customers/webs/anzenjo/anzenjo.riows-hosting.net/cc/system/classes/PageHandle.class.php(22): PageHandle->PostResponse()\n#4 /var/customers/webs/anzenjo/anzenjo.riows-ho in /var/customers/webs/anzenjo/anzenjo.riows-hosting.net/cc/system/classes/db.class.php on line 60,

    Hallo,


    ich habe ein dringendes Problem! Also ich schreibe gerade ein System.


    PostResponse wird vor dem Template noch ausgeführt


    Eine Function in der Session-Klasse

    PHP
    public function UserFetch($userid = 0)
    	{
    		$uid = ($userid == 0) ? $this->userid : $userid;
    		$this->db->Query("SELECT * FROM `accounts` WHERE `userid`=:uid");
    		$this->db->bind(':uid', $uid);
    		return var_dump($this->db);
    		//return $this->db->fetch();
    		//return ($this->db->rowCount()>0) ? $this->db->fetch() : NULL;
    	}


    Wenn ich es auf dem localhost-Webserver ausführe, geht alles wie es laufen sollte, jedoch wenn es Online ist, bekomme ich ein White-Screen. Es wird wohl immer NULL zurückgegeben.


    Ich kann mir den seltsamen Fehler nicht erklären. Kann mir einer Helfen?

    Als ich für LyD (Live your Dream) das UCP weiterentwickelt hatte, habe ich ein Control CMD rein geschrieben mit dem man möglichst viele Befehle wie Ingame ausführen kann. Das klappte aus. Nachteil jedoch ist, das der Spieler nicht ingame sein darf.


    Bei Bann hatte ich es so geregelt, das ich mit der SAMPQueryAPI den Spieler Kickte und zugleich den Ban verpasste.
    Nur mal so am Rande ;)

    Dein 2ter MySQL Fehler sagt aus, dass die Spalte hidden in deiner ausgewählen Tabelle nicht existiert.


    Gebe einfach mal den Code.


    Aber ich rate dir ab, mit PHP MSQL zu arbeiten da es seit glaube PHP5.3 als veraltet gilt und irgendwann von der PHP Liberly entfernt wird. Verwende lieber MySQLi oder PDO

    Hallo,
    kleines Problem:
    Mein Script findet in der Datenbank kein Haus inder Tabelle houses. Abwohl in der Datenbank sich ein haus mit der id 1 befindet.


    public mysql_CheckHaus(id)
    {
    new Query[128], debug4[100];
    format(Query, sizeof(Query), "SELECT * FROM houses WHERE id = '%i'", id);
    mysql_query(Query);

    mysql_store_result();
    format(debug4, sizeof(debug4),"Result von %i: %i", id, mysql_num_rows());
    print(debug4);
    return mysql_num_rows();
    }


    stock HausLaden()
    {
    new debug2[400], temp[200];
    for(new x=0;x<MAX_HAUS;x++)
    {


    if(mysql_CheckHaus(x)) {
    HausInfo[x][hErstellt] = 1;
    /*temp = mysql_GetStr_int("houses", "user", "id", x);
    format(HausInfo[x][hUser], 100, "%s", temp);*/
    format(HausInfo[x][hUser], 64, "%s", mysql_GetStr_int("houses", "user", "id", x));
    format(HausInfo[x][hEnterx], 64, "%f", mysql_GetFloat_int("houses", "enterx", "id", x));
    format(HausInfo[x][hEntery], 64, "%f", mysql_GetFloat_int("houses", "entery", "id", x));
    format(HausInfo[x][hEnterz], 64, "%f", mysql_GetFloat_int("houses", "enterz", "id", x));
    format(HausInfo[x][hIntx], 64, "%f", mysql_GetFloat_int("houses", "intx", "id", x));
    format(HausInfo[x][hInty], 64, "%f", mysql_GetFloat_int("houses", "inty", "id", x));
    format(HausInfo[x][hIntz], 64, "%f", mysql_GetFloat_int("houses", "intz", "id", x));
    HausInfo[x][hInt] = mysql_GetInt_int("houses", "int", "id", x);
    HausInfo[x][hMiete] = mysql_GetInt_int("houses", "miete", "id", x);
    HausInfo[x][hRent] = mysql_GetInt_int("houses", "rent", "id", x);
    HausInfo[x][hGesperrt] = mysql_GetInt_int("houses", "gesperrt", "id", x);
    HausInfo[x][hHauskasse] = mysql_GetInt_int("houses", "hauskasse", "id", x);
    HausInfo[x][hLevel] = mysql_GetInt_int("houses", "level", "id", x);
    HausInfo[x][hMuell] = mysql_GetInt_int("houses", "muell", "id", x);
    HausInfo[x][hHaustuer] = mysql_GetInt_int("houses", "haustuer", "id", x);
    HausInfo[x][hAddtime] = mysql_GetInt_int("houses", "addtime", "id", x);
    HausInfo[x][hVerkauft] = mysql_GetInt_int("houses", "verkauft", "id", x);
    format(HausInfo[x][hBeschreibung], 64, "%s", mysql_GetStr_int("houses", "beschreibung", "id", x));
    }
    if(HausInfo[x][hErstellt]==1)
    {
    format(debug2, sizeof(debug2), "[Haus] x: %f y: %f z: %f user: %s Müll: %i",HausInfo[x][hEnterx], HausInfo[x][hEntery], HausInfo[x][hEnterz], HausInfo[x][hUser], HausInfo[x][hMuell]);
    print(debug2);
    } else {
    format(debug2, sizeof(debug2), "[Haus] %i LEER",x);
    print(debug2);
    }

    }
    print("Häuser geladen!");
    return 1;
    }


    Wo ist da was falsch?



    Jeffry

    Jop alle MySQL-functions von PHP gelten als veraltet, die werden bald auc aus der Libery entfernt.


    Ich habe mal eine Datenbank-Klasse in PHP geschrieben was ich zurzeit für mich verwende. Feedback und Änderungsvorschläge gerne!


    Beispiele


    PHP
    $db = new Database;
    $db->Query("SELECT * FROM test WHERE id = 1");
    $db->execute();
    echo  $db->fetch()->testspalte;


    PHP
    $db = new Database;
    $testeintrag = 'Ich bin ein Test';
    $db->Query("INSERT INTO `test` (`testspalte`) VALUES (:bineinparam)");
    $db->bind(':bineinparam', $testeintrag);
    $db->execute();


    Die Klasse kannst du gern verwenden.


    Liebe Grüße