<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Bjellis Blog &#187; database</title>
	<atom:link href="http://welten.horus.at/category/computer/programmieren/db/feed/" rel="self" type="application/rss+xml" />
	<link>http://welten.horus.at</link>
	<description>sporadische selbstoffenbarungen auf die die welt nicht gewartet hat</description>
	<lastBuildDate>Fri, 30 Jul 2010 04:10:15 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.5</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Wordpress Datenbank Wahnsinn</title>
		<link>http://welten.horus.at/2008/06/wordpress-datenbank-wahnsinn/</link>
		<comments>http://welten.horus.at/2008/06/wordpress-datenbank-wahnsinn/#comments</comments>
		<pubDate>Thu, 26 Jun 2008 09:30:59 +0000</pubDate>
		<dc:creator>bjelli</dc:creator>
				<category><![CDATA[database]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[post-to-mma]]></category>
		<category><![CDATA[sql]]></category>
		<category><![CDATA[wordpress]]></category>

		<guid isPermaLink="false">http://welten.horus.at/?p=434</guid>
		<description><![CDATA[Ich liebe Wordpress.
Aber die Datenbank-Struktur von Wordpress, die hasse ich. Die ist soooo weit von relational entfernt, das ist unglaublich.  Da kriegen Datenbank-Profis schon Kopfweh wenn sie sich nur auf 100 Schritte nähern.
Heute wollt ich z.B. User aus einer Wordpress-Installation in eine andere Übernehmen.  Schaut auf den ersten blick ganz einfach aus: Inhalt der Tabelle [...]]]></description>
			<content:encoded><![CDATA[<p>Ich liebe Wordpress.</p>
<p>Aber die Datenbank-Struktur von Wordpress, die hasse ich. Die ist soooo weit von relational entfernt, das ist unglaublich.  Da kriegen Datenbank-Profis schon Kopfweh wenn sie sich nur auf 100 Schritte nähern.</p>
<p>Heute wollt ich z.B. User aus einer Wordpress-Installation in eine andere Übernehmen.  Schaut auf den ersten blick ganz einfach aus: Inhalt der Tabelle <strong>wp_user</strong> kopieren in die Datenbank des anderen Wordpress. Dort ist der &#8220;table_prefix&#8221; anders eingestellt, drum heisst die Tabelle dort <strong>wp_kids_users</strong>.</p>
<p>Auf den zweiten Blick seh ich: ich muss auch <strong>wp_usermeta</strong> kopieren auf <strong>wp_kids_usermeta</strong>.</p>
<p>Und dann kommt das dicke Ende: Mit der Fehlermeldung &#8220;You do not have sufficient permissions to access this page&#8221; bzw. &#8220;Ihre Zugriffsrechte reichen nicht aus, um diese Seite zu anzuzeigen.&#8221; verweigert das Wordpress-Backend den Zugriff.</p>
<p>Der Grund: In der Tabelle <strong>wp_kids_usermeta</strong> wird der Tabellen-Prefix auch verwendet:</p>
<p>Nach Schlüssel sortieren:</p>
<table id="table_results" class="data" border="1">
<tbody>
<tr>
<td>umeta_id</td>
<td>user_id</td>
<td>meta_key</td>
<td>meta_value</td>
</tr>
</tbody>
<tbody>
<tr class="odd">
<td class="nowrap" align="right">1</td>
<td class="nowrap" align="right">1</td>
<td>nickname</td>
<td>bjelli</td>
</tr>
<tr class="even">
<td class="nowrap" align="right">2</td>
<td class="nowrap" align="right">1</td>
<td>rich_editing</td>
<td>true</td>
</tr>
<tr class="odd">
<td class="nowrap" align="right">3</td>
<td class="nowrap" align="right">1</td>
<td><strong>wp_kids</strong>_capabilities</td>
<td>a:1:{s:13:&#8221;administrator&#8221;;b:1;}</td>
</tr>
<tr class="even">
<td class="nowrap" align="right">4</td>
<td class="nowrap" align="right">1</td>
<td><strong>wp_kids</strong>_user_level</td>
<td>10</td>
</tr>
<tr class="odd">
<td class="nowrap" align="right">5</td>
<td class="nowrap" align="right">1</td>
<td>first_name</td>
<td>Brigitte</td>
</tr>
<tr class="even">
<td class="nowrap" align="right">6</td>
<td class="nowrap" align="right">1</td>
<td>last_name</td>
<td>Jellinek</td>
</tr>
</tbody>
</table>
<p>D.h. bei Veränderung des Tabellennamens muss auch der Inhalt der Tabelle verändert werden, damit Wordpress weiterhin funktioniert:</p>
<p><strong>UPDATE {$newprefix}usermeta SET meta_key = &#8220;{$newprefix}capabilities&#8221; WHERE meta_key = &#8220;{$oldprefix}capabilities&#8221;;<br />
UPDATE {$newprefix}usermeta SET meta_key = &#8220;{$newprefix}user_level&#8221; WHERE meta_key = &#8220;{$oldprefix}user_level&#8221;;</strong></p>
<p>Liebe Leute: nehmt Euch Wiordpress nicht als Vorbild für Datenbank-Design, macht das nicht nach. Schön ist anders.</p>
]]></content:encoded>
			<wfw:commentRss>http://welten.horus.at/2008/06/wordpress-datenbank-wahnsinn/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>
