<?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>Caio&#039;s Blog &#187; Database</title>
	<atom:link href="http://www.dreamtec.it/caioblog/index.php/tag/database/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.dreamtec.it/caioblog</link>
	<description>A life in technique</description>
	<lastBuildDate>Sun, 15 Aug 2010 14:24:27 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>Visio for Enterprise Architects on Vista X64 (VS2008 installed)</title>
		<link>http://www.dreamtec.it/caioblog/index.php/2009/07/visio-for-enterprise-architects-on-vista-x64-vs2008-installed/</link>
		<comments>http://www.dreamtec.it/caioblog/index.php/2009/07/visio-for-enterprise-architects-on-vista-x64-vs2008-installed/#comments</comments>
		<pubDate>Wed, 29 Jul 2009 22:35:36 +0000</pubDate>
		<dc:creator>Caio</dc:creator>
				<category><![CDATA[Enjoy]]></category>
		<category><![CDATA[PiCi]]></category>
		<category><![CDATA[64bit]]></category>
		<category><![CDATA[Database]]></category>
		<category><![CDATA[MSSQL]]></category>
		<category><![CDATA[tecnica]]></category>
		<category><![CDATA[Visio]]></category>
		<category><![CDATA[Vista]]></category>
		<category><![CDATA[Visual Studio]]></category>

		<guid isPermaLink="false">http://www.dreamtec.cc/caioblog/?p=582</guid>
		<description><![CDATA[Chiunque conosca Visio for enterprise Architects sa quanto possa essere comodo uno strumento del genere quando si deve progettare lo schema ER di un database di medie dimensioni (&#62;= 20~40 tabelle), impostando le relazioni, le azioni da compiere sugli aggiornamenti e tutto ciò che si fa durante la creazione di un DB, per non parlare [...]]]></description>
			<content:encoded><![CDATA[<p>Chiunque conosca <a href="http://msdn.microsoft.com/it-it/library/ms182014%28VS.80%29.aspx" target="_blank" class="liexternal">Visio for enterprise Architects</a> sa quanto possa essere <strong>comodo </strong>uno strumento del genere quando si deve progettare lo <a href="http://it.wikipedia.org/wiki/Modello_E-R" target="_blank" rel="nofollow" class="liwikipedia">schema ER</a> di un database di medie dimensioni (&gt;= 20~40 tabelle), impostando le relazioni, le azioni da compiere sugli aggiornamenti e tutto ciò che si fa durante la creazione di un DB, per non parlare di quanto <strong>tempo </strong>si possa <strong>risparmiare </strong>generando automaticamente la controparte fisica dello schema<sup><a href="http://www.dreamtec.it/caioblog/index.php/2009/07/visio-for-enterprise-architects-on-vista-x64-vs2008-installed/#footnote_0_582" id="identifier_0_582" class="footnote-link footnote-identifier-link" title="tipicamente in mssql">1</a></sup> sfruttando il driver <a href="http://it.wikipedia.org/wiki/ODBC" target="_blank" rel="nofollow" class="liwikipedia">odbc</a> che ne consente l&#8217;integrazione con un gran numero di database.</p>
<p>Purtroppo allo stato attuale pare non essere ancora disponibile alcuna versione aggiornata di questa particolare versione  di Visio, che tra i prerequisiti necessita di nientepocodimenochè di VS2005, per cui doverlo installare su una macchina di sviluppo su cui magari sono già installati altri <a href="http://it.wikipedia.org/wiki/Integrated_development_environment" target="_blank" rel="nofollow" class="liwikipedia">IDE</a> può diventare davvero esoso in termini di <strong>spazio </strong>richiesto, per non parlare del fatto che di quella istanza di VS2005 non ce ne faremmo nulla e generalmente la cosa può infastidire un po..</p>
<p><strong>Fortunatamente </strong>c&#8217;è la possibilità, con un piccolo trick, come si fa per l&#8217;installazione sotto XP, di installare il tutto senza *davvero* installarsi anche Visual Studio 2005, ma semplicemente facendo <strong>credere </strong>all&#8217;installer che ciò che cerca ci sia veramente e che quindi si possa procedere oltre.</p>
<p>E&#8217; bene specificare che, affinchè il tutto funzioni è necessario che sulla macchina sia installato VS2008, visto che il giochino delle chiavi si basa proprio su quelle create dopo l&#8217;installazione di questa versione<sup><a href="http://www.dreamtec.it/caioblog/index.php/2009/07/visio-for-enterprise-architects-on-vista-x64-vs2008-installed/#footnote_1_582" id="identifier_1_582" class="footnote-link footnote-identifier-link" title=" i pi&ugrave; intrepidi potrebbero provare un&amp;#8217;installazione importando delle chiavi generate da altri pc, prerequisiti per il funzionamento a parte (che potrebbero far crashare il programma in esecuzione) l&amp;#8217;installazione potrebbe terminare con successo">2</a></sup>.</p>
<p>Quello che bisogna fare, su Vista X64, è:</p>
<ol>
<li>Esportarsi separamente le 2 chiavi di registro:
<pre class="brush: c#">Computer\HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Visual Studio\9.0

Computer\HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Visual Studio\8.0
</pre>
<p>(Se la chiave 8.0 non è presente non è importante, la importeremo noi al punto successivo)</li>
<li>A questo punto ci si crea una copia della chiave 9.0 e la si mette da parte, perchè ci servirà come ultimo punto.</li>
<li>Successivamente si apre il file contenente la chiave 9.0 con il notepad, e si sostituiscono tutte le istanze della stringa &#8220;9.0&#8243; con &#8220;8.0&#8243;.</li>
<li>Fatto questo si reimporta la chiave di registro appena modificata, e da questo momento in avanti l&#8217;installazione di Visio for Enterprise Architects procederà senza problemi fino alla fine convinto che tutti i componenti siano installati come lui si aspetta.</li>
<li>Una volta terminata l&#8217;installazione, onde evitare <a href="http://images.google.it/images?hl=it&amp;q=bsod&amp;um=1&amp;ie=UTF-8&amp;ei=X81wStiZDYKi_ga8ne3jCg&amp;sa=X&amp;oi=image_result_group&amp;ct=title&amp;resnum=4" target="_blank" class="liexternal">inutili attacchi di panico da parte di windows</a> dovuto a situazioni non previste nel registro, è necessario ripristinare la condizione precedente alla modifica ripristinando le chiavi furbescamente modificate.Per farlo è sufficiente reimportare le 2 chiavi esportare inizialmente, facendo chiaramente attenzione a importare la copia originale della chiave 9.0 che avevamo ci si era creati subito dopo l&#8217;esportazione.</li>
</ol>
<ol class="footnotes"><li id="footnote_0_582" class="footnote">tipicamente in mssql</li><li id="footnote_1_582" class="footnote"> i più intrepidi potrebbero provare un&#8217;installazione importando delle chiavi generate da altri pc, prerequisiti per il funzionamento a parte (che potrebbero far crashare il programma in esecuzione) l&#8217;installazione potrebbe terminare con successo</li></ol>]]></content:encoded>
			<wfw:commentRss>http://www.dreamtec.it/caioblog/index.php/2009/07/visio-for-enterprise-architects-on-vista-x64-vs2008-installed/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Multiple dbml with same tables</title>
		<link>http://www.dreamtec.it/caioblog/index.php/2009/05/multiple-dbml-with-same-tables/</link>
		<comments>http://www.dreamtec.it/caioblog/index.php/2009/05/multiple-dbml-with-same-tables/#comments</comments>
		<pubDate>Thu, 14 May 2009 20:03:43 +0000</pubDate>
		<dc:creator>Caio</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[compiler error]]></category>
		<category><![CDATA[Database]]></category>
		<category><![CDATA[DBML]]></category>
		<category><![CDATA[LINQ]]></category>
		<category><![CDATA[SQL]]></category>
		<category><![CDATA[tecnica]]></category>
		<category><![CDATA[Visual Studio]]></category>

		<guid isPermaLink="false">http://www.dreamtec.cc/caioblog/?p=554</guid>
		<description><![CDATA[Probabilmente non è una di quelle operazioni che si compiono quotidianamente, ma pare non ci siano molte informazioni in giro riguardo a come includere diversi modelli dbml, contenenti le stesse tabelle, all&#8217;interno di un&#8217;unico progetto in Visual Studio, per cui ritengo valga la pena scriversi 2 appunti. Poniamo il caso in cui sia necessario utilizzare [...]]]></description>
			<content:encoded><![CDATA[<p style="text-align: justify;"><a href="http://www.dreamtec.cc/caioblog/wp-content/uploads/2009/05/diagram.jpeg" class="liimagelink" rel="lightbox[554]"><img class="alignleft size-full wp-image-553" style="border: 5px solid white;" title="diagram dbml" src="http://www.dreamtec.cc/caioblog/wp-content/uploads/2009/05/diagram.jpeg" alt="diagram dbml" width="419" height="695" /></a> Probabilmente non è una di quelle operazioni che si compiono quotidianamente, ma pare non ci siano molte informazioni in giro riguardo a come includere diversi <strong>modelli dbml</strong>, contenenti le stesse tabelle, all&#8217;interno di un&#8217;unico progetto in Visual Studio, per cui ritengo valga la pena scriversi 2 appunti.</p>
<p style="text-align: justify;">Poniamo il caso in cui sia necessario utilizzare dei database che contengono per caso 2 <strong>tabelle uguali</strong>, o in cui comunque ci siano gli stessi nomi di tabella, e includerli in un modello <strong>LINQ to SQL</strong> per riutilizzarli ad esempio con dynamic data.</p>
<p style="text-align: justify;">Se ci limitiamo a creare i dbml e ad aggiungervi le tabelle del nostro DB, al primo CTRL + B il compilatore di Visual Studio fallirà riportando tanti errori quante ridefinizioni delle stesse tabelle troverà.</p>
<p style="text-align: justify;">Per risolvere questo problema è sufficiente aggiungere un <strong>Context Namespace</strong> ed un <strong>Entity Namespace</strong> per ogni dbml, in modo che durante la compilazione non ci saranno conflitti nella dichiarazione delle classi (visto che le tabelle sono rappresentate da classi nel dbml).</p>
<p style="text-align: justify;"><a href="http://www.dreamtec.cc/caioblog/wp-content/uploads/2009/05/dbml.jpg" class="liimagelink" rel="lightbox[554]"><img class="alignleft size-full wp-image-555" title="dbml" src="http://www.dreamtec.cc/caioblog/wp-content/uploads/2009/05/dbml.jpg" alt="dbml" width="303" height="227" /></a></p>
<p style="text-align: justify;">Ovviamente sarà necessario scegliere la connessione corretta per gestire il DB relativo al dbml, dichiarata preventivamente nel <strong>web.config</strong>, e visto che probabilmente vorremo usare il dbml nel progetto, ad esempio con dynamic data, dovremo modificare il<strong> global.asax</strong> dicendogli di utilizzare il datacontext corretto ed eventualmente registrando le nuove routes.</p>
<p style="text-align: justify;">Un buon articolo su come fare per registrare diverse routes di diversi dbml <a href="http://blogs.msdn.com/davidebb/archive/2008/12/11/using-dynamic-data-with-multiple-databases.aspx" target="_blank" class="liexternal">è disponibile qui</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.dreamtec.it/caioblog/index.php/2009/05/multiple-dbml-with-same-tables/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Database diagrams MSSQL</title>
		<link>http://www.dreamtec.it/caioblog/index.php/2009/04/database-diagrams-mssql/</link>
		<comments>http://www.dreamtec.it/caioblog/index.php/2009/04/database-diagrams-mssql/#comments</comments>
		<pubDate>Fri, 03 Apr 2009 12:10:06 +0000</pubDate>
		<dc:creator>Caio</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Database]]></category>
		<category><![CDATA[MSSQL]]></category>
		<category><![CDATA[SQL]]></category>

		<guid isPermaLink="false">http://www.dreamtec.cc/caioblog/?p=509</guid>
		<description><![CDATA[TITLE: Microsoft SQL Server Management Studio Express &#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212; Database diagram support objects cannot be installed because this database does not have a valid owner. To continue, first use the Files page of the Database Properties dialog box or the ALTER AUTHORIZATION statement to set the database owner to a valid login, then add the database [...]]]></description>
			<content:encoded><![CDATA[<p style="text-align: center;"><a href="http://www.dreamtec.cc/caioblog/wp-content/uploads/2009/04/mssq_error.jpeg" class="liimagelink" rel="lightbox[509]"><img class="size-full wp-image-511 aligncenter" title="mssq_error" src="http://www.dreamtec.cc/caioblog/wp-content/uploads/2009/04/mssq_error.jpeg" alt="mssq_error" width="612" height="148" /></a></p>
<p style="text-align: center;">
<p>TITLE: Microsoft SQL Server Management Studio Express<br />
&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;</p>
<p>Database diagram support objects cannot be installed because this database<br />
does not have a valid owner. To continue, first use the Files page of the<br />
Database Properties dialog box or the ALTER AUTHORIZATION statement to set<br />
the database owner to a valid login, then add the database diagram support<br />
objects.</p>
<p>&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;</p>
<p>Questo post è un promemoria per chi (come me) non si ricorda a memoria come modificare i permessi per la creazione del diagram (molto utile per la visualizzazione del DB nel suo insieme, relazioni incluse) in MSSQL Management studio e ha bisogno di una stringa da utilizzare al volo per farlo.<img src="file:///C:/DOCUME%7E1/Caio/LOCALS%7E1/Temp/moz-screenshot-28.jpg" alt="" /></p>
<p>La query giusta da eseguire in questo caso è:</p>
<pre class="brush: sql">

EXEC sp_dbcmptlevel &#039;$NOMEDB&#039;, &#039;90&#039;;

ALTER AUTHORIZATION ON DATABASE::$NOMEBD TO &quot;$NOMEMACCHINA\$USERNAME&quot;
</pre>
<p>ovviamente con le opportune sostituzioni sulle variabili $&#8230;.cheers <img src='http://www.dreamtec.it/caioblog/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.dreamtec.it/caioblog/index.php/2009/04/database-diagrams-mssql/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>
