Seite 1 von 1

bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 01.01.2009 22:46
von leopittoni
Hallo!

Wie kann ich allgemein, wenn ich mit PHP einen Datensatz einfüge, zuerst überprüfen, ob es diesen bereits gibt?
Also:
zufallszahl = x
gibt es schon einen Datensatz mit zahl=x?

ja -> neuanfang!
nein -> daten einfügen -> Ende
Danke, Léo

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 01.01.2009 22:57
von PhilippK
In dem du ein SELECT auf die Datenbank machst und prüfst, ob du ein Ergebnis erhältst.

Gruß, Philipp

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 01.01.2009 23:14
von leopittoni

Code: Alles auswählen

	function passgen($length) {
		$str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
		$str = str_shuffle($str);
		$password = substr($str, 0, $length);
	return $password;
}

$forum_code = passgen(10);

$sql = "SELECT forum_id
		FROM FORUMS_TABLE
		WHERE forum_passwort = $forum_code"; 

	if( !$result = $db->sql_query($sql) )
	{
	}
	else
	{
$forum_code = passgen(10);
}
So wärs theoretisch ok, nur muss ich da irgendwie eine Schlaufe reinbringen... Der neue Code (unwahrscheinlich aber trotzdem) muss auch wieder überprüft werden, ob er bereits exisitert...

Danke, Léo

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 02.01.2009 00:07
von Miriam
Was möchtest Du denn genau machen?

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 02.01.2009 21:37
von leopittoni
Per PHP einen zufallscode in die DB einfügen.

Der Code wird so generiert:

Code: Alles auswählen

 function passgen($length) {
      $str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
      $str = str_shuffle($str);
      $password = substr($str, 0, $length);
   return $password;
}

$forum_code = passgen(10);
Ein Code darf nicht doppelt in der DB vorkommen, deshalb sollte vor dem Einfügen in die DB nach bereits vorhanden Datensätzen mit demselben Code gesucht werden. Gibt es diese schon, muss das ganze Script von vorne beginnen: Neuer Code erzeugt-> dieser wieder überprüfen.

Danke für die Hilfe!

Léo

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 02.01.2009 23:08
von Miriam
So vllt?

Code: Alles auswählen

function passgen($length) 
{
	$str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
	$str = str_shuffle($str);
	$password = substr($str, 0, $length);
	return $password;
}

do 
{
	$forum_code = passgen(10);
	$sql = "SELECT forum_id
			FROM FORUMS_TABLE
			WHERE forum_passwort = $forum_code";
}
while ($result = $db->sql_query($sql));
//
// hier kommt das Einfügen des $forum_code
//

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 03.01.2009 00:03
von PhilippK
Sofern die Voraussetzungen passen, gibt es dann natürlich noch einen anderen Weg:
Das Feld in der Datenbank als UNIQUE markieren. Dann einfach den Datensatz einfügen und prüfen, ob der Vorgang erfolgreich war. Wenn nicht, musst du eine neue ID erstellen.

Gruß, Philipp

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 05.01.2009 21:47
von Boecki91
Bei den Foren mag das zwar noch nicht ganz so Wild sein, aber je mehr Einträge in der DB sind, desto mehr Abfragen gibt es, wobei bei 3656158440062976 theoretischen (36 hoch 10) Möglichkeiten es sehr viele Foren braucht um das zu erreichen, aber fals das jemand mit weniger Stellen aber mehr Einträgen plant sollte er das bedenken, vielleicht eine maximale Suchabfragen Anzahl festlegen und die Anzahl der Stellen beim Misslingen erhöhen.

Re: bei Einfügen nach doppelten Datensätzen suchen?

Verfasst: 09.02.2009 22:51
von leopittoni

Code: Alles auswählen

	
function passgen($length) {
		$str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
		$str = str_shuffle($str);
		$password = substr($str, 0, $length);
return $password;
}


//10 stelliger Zufallscode erzeugen
$forum_code = passgen(10);

//Gibt es den Coder bereits?
$sql = mysql_query("SELECT forum_id
		FROM support_codes
		WHERE forum_code = '$forum_code'"); 

$result = mysql_fetch_array($sql);

//Solange es den Code bereits gibt, immer einen neuen erzeugen
	if($result)
	{
	while ($result) 
		{
		$forum_code = passgen(10);
		//Gibt es den Coder bereits?
		$sql = mysql_query("SELECT forum_id
		FROM support_codes
		WHERE forum_code = '$forum_code'"); 

		$result = mysql_fetch_array($sql);
		}
	}
	
$sql = "INSERT INTO support_codes (forum_id, forum_code)
				VALUES ('".$forum_identify."', '".$forum_code."')";
Ich habe das nun so etwas zusammengebastelt. Ist das dasselbe wir Miriam's Lösung, nur etwas komplizierter?

Und ja: es wird relativ viele Datensätze geben. Ich möchte bei der Überprüfung nicht den Server in die Knie zwingen, gibts da eine schonendere Lösung?

Danke, Léo