Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Tipps & Tricks ›

Feldeinstellunge nachträglich ändern

Eingetragen von olivers67 (26)
am 01.07.2013 - 16:39 Uhr in
  • Tipps & Tricks
  • Drupal 7.x

Hallo,

hatte das Problem ein Textfeld von zwei auf drei Zeichen aufzubohren, wusste aber nicht wie:

zwei Tabellen am besten mit phpmyadmin filed_data_field_ und field_data_revision_ , bei mir was ein varchar(2) auf varchar(3) zu ändern. ABER vorsichtig genau überlegen was die Änderung für deinen Datenbestand bedeutet!!!

dann das Blob-Feld "Data" in field_config bearbeiten.

bei phpmyadmin muss man bei der select Abfrage noch ein bischen an den Optionen etwas einstellen um auch einen lesbaren Text zu erhalten.

Vollständige Texte
Relationaler Schlüssel
Binäre Inhalte anzeigen
BLOB Inhalte anzeigen
Binäre Inhalte in hexadezimal anzeigen
Darstellungsumwandlung ausblenden
Geometrie

Mit diesen Optionen hat es bei mir Funktioniert

Original :
http://drupal.stackexchange.com/questions/8829/how-to-change-the-length-...

Hier die Anleitung mit Google-Übersetzer:
Dylan Tack Lösung ist die einfachste, aber ich persönlich genießen die Erkundung der inneren Bezirke von Drupal Datenbank zu sehen, wie die Dinge sich dort verwaltet.

Also, vorausgesetzt, Sie haben ein Textfeld die Maschine Name ist field_text von 10 Zeichen, die Sie auf 25 wachsen:

Daten werden in zwei Tabellen gespeichert werden: field_data_field_text und field_revision_field_text
Definition wird in field_config für die Speicherung von Daten gespeichert und field_config_instance für jede Instanz dieses Feldes (Sachen wie Label).

Lassen Sie uns nun ein wenig Herzchirurgie.

Ändern Sie die Datentabellen Spalten Definitionen:

ALTER TABLE `field_data_field_text` CHANGE `field_text_value` `field_text_value` VARCHAR( 25 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL; ALTER TABLE `field_revision_field_text` CHANGE `field_text_value` `field_text_value` VARCHAR( 25 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL;

Ändern Sie die Definition Spalte, ist dies eine sehr heikle, weil es in einem BLOB gespeichert ist, aber das ist nicht etwas, das Sie tun dies zu stoppen.
Präparieren Sie den Mut, dieses BLOB Sache:

SELECT CAST(`data` AS CHAR(10000) CHARACTER SET utf8) FROM `field_config` WHERE field_name = 'field_text';

Dadurch erhalten Sie so etwas wie:

a:7:{s:12:"translatable";s:1:"1";s:12:"entity_types";a:0:{}s:8:"settings";a:2: {s:10:"max_length";s:2:"10";s:17:"field_permissions";a:5: //a lot more stuff...

Dies ist ein PHP serialisierten Array, der interessante Teil ist s:10:"max_length";s:2:"10"; , meine das dieses Array hat eine Eigenschaft namens max_length (dessen Name ist ein 10 Zeichen String - daher das "s "), welcher Wert ist 10 (das ist ein 2 Zeichen langen String). Es ist ziemlich einfach, nicht wahr?

Ändern seines Wertes ist so einfach wie das Ersetzen des s:2:"10" Teil von s:2:"25" . Seien Sie vorsichtig: wenn Ihre neue Wert ist länger, müssen Sie die "s" Teil anzupassen, beispielsweise indem 100 wird sein s:3:"100" als 100 beträgt 3.

Lasst uns diesen neuen Wert zurück in die DB, vergessen Sie nicht, den ganzen String zu halten.

UPDATE `field_config` SET data = 'a:7:{...a:2:{s:10:"max_length";s:2:"25";...}' WHERE `field_name` = 'field_text'

Spülen Sie Ihren Caches.

??

GEWINN!

By the way, hat PhpMyAdmin einige Einstellungen zu ermöglichen direkte Änderung von BLOB-Spalten , aber warum gehen den einfachen Weg?

PS: Dies kann auch Ihr Leben retten, wenn setzen einige PHP-Code in Ansichten und bekommen eine WSOD aufgrund eines Fehlers im Code.

‹ [HOWTO] Das Order total Übersetzungsproblem in Drupal commerce [gelöst] Wie erstelle ich eine Datenbank in welche Benutzer Daten eintragen können ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Probleme mit der darstellun der ogg:image Tags.
  • [gelöst]Abhängigkeiten zweier oder mehrerer Inhaltstypen
  • Lokale Entwicklungsumgebung auf Windows
  • Drupalcenter tot?
  • Drupal-Forks und ihre Schwächen/Stärken
  • Was kann ich gegen ständige Blutergüsse tun?
  • Mir gefällt die Drupal Symfony und deren Composer
  • Mir ist da was aufgefallen ;)
  • Matomo Installation
  • Verständnisfrage private_files in Drupal
  • [gelöst] Drupal 7 Forum Beitrag mit Bilder einstellen
  • erfahrung mit dem Modul script manager
Weiter

Neue Kommentare

  • Kontextfilter und Relationen sind der richtige Ansatz
    vor 16 Stunden 12 Minuten
  • Zusatzfragen
    vor 1 Tag 17 Stunden
  • DDEV verwaltet Container, sowohl Docker als auch andere
    vor 1 Tag 17 Stunden
  • Entwicklungsumgebung ist nicht nur Server
    vor 1 Tag 17 Stunden
  • Danke
    vor 3 Tagen 48 Minuten
  • [gelöst] Danke!
    vor 3 Tagen 53 Minuten
  • Ja natürlich tun wir dass.
    vor 3 Tagen 19 Stunden
  • Drupal.de verweist aufs Drupal Center
    vor 3 Tagen 20 Stunden
  • Und falls du auf grüne
    vor 3 Tagen 21 Stunden
  • Danke euch beiden, das bringt
    vor 3 Tagen 21 Stunden

Statistik

Beiträge im Forum: 250046
Registrierte User: 20363

Neue User:

  • LilliNELP
  • Wavermype
  • tom082

» Alle User anzeigen

User nach Punkten sortiert:
wla9456
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3855
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 2 User und 11 Gäste online.

Benutzer online

  • dinmikkith
  • wla

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association