quinta-feira, 9 de outubro de 2014

SQLServer 2008 - Reset do valor de uma sequência de uma campo Entity

Por vezes, quer por questões de migração de dados, updates ou outros casos, é preciso redefinir ou alterar o valor atual do gerador de números sequênciais para um determinada coluna de uma tabela numa Base de Dados. No caso do SqlServer 2008, não existe o conceito de SEQUENCE tal como em outras BDs (Oracle, etc...), mas existe algo minimamente equivalente que é o tipo Entity atribuído a uma única coluna da tabela em questão. O facto de só poder existir uma coluna/campo com o tipo Entity, acrescido do facto de não se poderem manipular as sequencias isoladamente como um objecto normal da BD, são as maiores diferenças desta implementação face a outras BDs. Assim, sendo como fazer, quando se quer alterar a sequência (o próximo id/Entity) a ser gerado ?
DBCC CHECKIDENT( 'nome_do_schema.nome_da_tabela', reseed, novo_numero_de_sequencia );
Se quisermos por exemplo fazer reset da sequência de forma ao próximo registo inserido ter a coluna/campo Entity com o valor 10000, deveremos executar o comando, de forma a configurar a sequência para o número anterior, dado que a sequência guarda o último número gerado, gerando o seguinte a partir desse mais o incremento definido. NOTA: Ter atenção nos casos em que o incremento da sequência não foi definido como 1, pois ai o próximo número será o número guardado na sequência mais o incremento definido. Assumindo então um schema com o nome "schema_teste" e uma tabela de nome "tabela_teste", para uma nova sequência da coluna/campo entity a começar em 10000, executariamos o seguinte comando.
DBCC CHECKIDENT( 'schema_teste.tabela_teste', reseed, 9999 );
AVISO: Obviamente, se uma sequência for alterada de forma a que possa gerar IDs idênticos a registos que já existam, irão surgir erros relativos à UNIQUE CONSTRAINT que é definida implicitamente para uma coluna/campo do tipo Identity. Habitualmente aumenta-se o número da sequência, e só em casos especiais se reduz, devido a necessidade de garantir a unicidade do identificador (Identity).

quinta-feira, 21 de agosto de 2014

Firefox URLEncode Feature

Hoje, dei-me conta que o Firefox (versão 31.0), tem uma feature (funcionalidade), que pode ser bastante prática/util para um developer, nomeadamente fazer o URL encode de qualquer texto que se introduza no campo de endereço. Por exemplo: Escrever ou fazer copy&paste do seguinte:
http://www.google.com/olá.olé.olí
Se a seguir selecionarem o endereço (Ctrl+A ou usando o rato) e copiarem o seu conteúdo (Ctrl+C), quando fizerem Paste (Ctrl+V) por exemplo no notepad ou semelhante, vão ver a String original URL encoded. Para o exemplo anterior será:
http://www.google.com/ol%C3%A1.ol%C3%A9.ol%C3%AD
Sempre é mais rápido do que ir pesquisar um site na net, para fazer o mesmo. Ou para os mais geeks, chamar a funcão javascript para fazer o encode directamente no campo do endereço.
javascript:encodeURI("www.google.com/olá.olé.olí")

quinta-feira, 10 de abril de 2014

Descobri um problema irritante com o IE7/8, e a sua implementação de AJAX.
Basicamente, se usarem JQuery, para fazer pedidos ao servidor, estes são feitos, usando o charset "UTF-8", e está documentado. Funciona correctamente se usarmos browsers considerados "normais", como: Firefox, Chrome, etc... mas no caso do IE não podia ser assim não é verdade ...
No caso do IE7, o pedido vai para o servidor e leva o "header" ("Content-Type:") correctamente definido, mas o IE7, simplesmente não faz a conversão dos dados para o formato correcto.
Para funcionar em IE7/8, é necessário forçar o contentType na chamada ajax do JQuery, semelhante a isto:

$("form#myForm").ajaxForm(
 {
  contentType: 'application/x-www-form-urlencoded; charset=UTF-8',
  success:
   function( data )
   {
    alert( 'success' );
   }
 } );

WebGl no Firefox

Como ativar o WebGl no Firefox. Os passos são simples:
  1. Aceder a "about:config" na barra de endereços
  2. pesquisar por "webgl", na página "about:config"
  3. alterar ou verificar que as seguintes configurações estão a "false"
    • webgl.disabled
  4. alterar ou verificar que as seguintes configurações para "true"
    • webgl.force-enabled
    • webgl.force-layers-readback (algumas aplicações precisam deste setting)
    • webgl.prefer-native-gl (optimização)
NOTA: Para alterar uma configuração basta fazer double click. Algumas aplicações para testar se o WebGl está ativo e a funcionar.