php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > SQL / Datenbanken
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


SQL / Datenbanken Probleme mit SQL? Hier könnt ihr eure Fragen zu SQL (MySQL, PostgreSQL, MS-SQL und andere ANSI-SQL Server) los werden.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 13-11-2006, 14:08
zonthor
 Newbie
Links : Onlinestatus : zonthor ist offline
Registriert seit: Mar 2006
Ort: Vechelde
Beiträge: 115
zonthor ist zur Zeit noch ein unbeschriebenes Blatt
zonthor eine Nachricht über ICQ schicken
Standard [MySQL 4.1] Datensatz Dublizieren

Hi,

gibt es eine Möglichkeit einen Datensatz zu Kopieren ohne alle Splatennamen aufzuführen:

Ich habe mir etwas in der Richtung vorgestellt:

INSERT INTO ´TBL´ ( SELECT * FROM ´TBL´ WHERE PK = 1 )


Jedoch mit neuem Autowert den ich mittels last_insert_id abfragen kann.


Danke basti
Mit Zitat antworten
  #2 (permalink)  
Alt 14-11-2006, 02:45
zonthor
 Newbie
Links : Onlinestatus : zonthor ist offline
Registriert seit: Mar 2006
Ort: Vechelde
Beiträge: 115
zonthor ist zur Zeit noch ein unbeschriebenes Blatt
zonthor eine Nachricht über ICQ schicken
Standard

falls jemand Interesse an meiner Lösung oder einen Konstruktiven Verbesserungsvorschlag dazu hat:

PHP-Code:
  /**
   * Dubliziert einen Datensatz in einer Tabelle
   *
   * @param $tbl Name der Tabelle in der gearbeitet werden soll
   * @param $pk Wert des Primärschlüssels des zu dublizierenden Datensatzes
   * @return Wert des Primärschüssels des Dublikats
   *
   **/
  
function dublicate_record($tbl$pk){
    
// Primärschüssel suchen
    
$this->query("SHOW COLUMNS FROM $tbl WHERE `Key`='PRI'");
    
// Ein Primärschüssel mit auto_increment ?
    
if($this->count() == && $this->fetch_field('Extra') == 'auto_increment'){
      
// Feldliste erstellen
      
$primary_field $this->fetch_field('Field');
      
$this->query("SHOW COLUMNS FROM $tbl");
      
$fields    '';
      
$seperator '';
      while(
$field $this->fetch()){
        if(
$field['Key'] != 'PRI'){
          
$fields.=$seperator "`$field[Field]`";
          
$seperator ', ';
        }
      }
      
// Datensatz Dublizieren
      
$this->query("INSERT INTO $tbl  ($fields) (SELECT $fields FROM $tbl WHERE $primary_field = '$pk')");
      return 
$this->last_insert_id();
    }else{
      return 
false;
    }
  } 
Ich habe die Lösung als Methode in meiner MySQL-Klasse implementiert, aber ich denke die verwendeten Methoden sind verständlich
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

Projektmanagement Damals und Heute
Projektmanagement Damals und HeuteWerfen Sie einen Blick auf das, was sich verändert hat, und entdecken Sie, wo die Zukunft dieses Gebietes hinsteuert.

18.01.2021 | Berni

Arbeitsmanagement-Tools
Arbeitsmanagement-ToolsWarum jedes Team Arbeitsmanagement-Tools benötigt. Man schätzt, dass 25% eines durchschnittlichen Mitarbeiter-Tages durch ineffiziente Arbeit vergeudet werden.

11.12.2020 | Berni


 

Aktuelle PHP Scripte

Formmailer Bootstrap 4

Mit dem Formmailer kann man sich eMails über seine Seite zukommen lassen.

08.07.2021 arne-home | Kategorie: PHP/ Formular
Fehlerseite Bootstrap 4

Bei Aufruf einer nicht existierenden Seite, teilen Sie Besuchern mit einer eigenen Fehlerseite mit, dass die gewünschte Seite nicht gefunden wurde. Die eigene Fehlerseite sollte dasselbe Design wie die Website haben. Zudem sollte ein Link zur Startseite a

04.07.2021 arne-home | Kategorie: PHP/ Counter
Upload Bootstrap 4

Mit dem PHP - Uploadscript kann man schnell und einfach Bilder und Dateien auf den Webserver hochladen.

04.07.2021 arne-home | Kategorie: PHP/ File
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 17:45 Uhr.