Avançar para o conteúdo principal

DB2 Viper - Overview de funcionalidades

A IBM anunciou a disponibilidade de uma nova versão da sua base de dados DB2, denominada DB2 Viper.

Nesta versão foram implementadas muitas novas funcionalidades e corrigidos bugs.

A principal nova característica consiste no suporte "puro" de XML nas bases de dados, mantendo - como é óbvio - todas as funcionalidades relacionais e object relational.
O suporte para XML até aqui existente no DB2 era:
  • Inserção do XML em Blob(s), com um sql alterado para o facilitar.
  • Mapeamento de tag(s) XML com colunas da base de dados relacional fazendo com que os ficheiros XML ao serem inseridos fossem convertidos em informação em colunas de tabelas numa bd relacional tradicional.
Já existiam várias bases de dados XML (ex : Apache Xindice, Software AG Tamino). Esta versão disponibiliza o melhor de dois mundos (Relacional e XML).
Por suporte "puro" entende-se:
  • A gravação da informação XML de uma forma hierarquica.
  • O suporte da linguagem XQuery para consulta da informação.
A arquitectura simplificada deste acesso descreve-se no seguinte diagrama:










De notar que em termos de organização tabular nada muda. Passa é a existir um novo tipo de dados XML, como se pode ver na tabela que se segue:

create table cliente (
numero smallint,
nome char(100),
info_contacto xml
);

Para inserir em tal tabela usa-se uma instrução SQL normal, como por exemplo:
insert into clients values (77, 'josé manuel',
'Rua das pretas111Lisboa');

Os query(s) podem ser executados em SQL puro ou em Xquery.

Comentários

Mensagens populares deste blogue

[Off-topic] "Novas" tendências de gestão

Afinal as novas tendências de gestão não são de agora. E as suas consequências também já são conhecidas há muito. Vejam esta carta do Senhor Vauban , Engenheiro Militar e Marechal de França, dirigida ao Senhor Losvois, Ministro da Guerra de Luís XIV, datada de 17 de Julho de 1683. "Monsenhor: ... Há alguns trabalhos nos últimos anos que não acabaram e não acabarão nunca, e tudo isso, Monsenhor, porque a confusão que causam as frequentes baixas de preços que surgem nas suas obras só servem para atrair como empreiteiros os miseráveis, malandros ou ignorantes e afugentar aqueles que são capazes de conduzir uma empresa. Digo mais, deste modo eles só atrasam e encarecem as obras consideravelmente porque essas baixas de preços e economias tão procuradas são imaginárias, dado que um empreiteiro que perde, faz o mesmo que um náufrago que se afoga, agarra-se a tudo o que pode; e agarrar-se a tudo, no ofício de empreiteiro, é não pagar aos fornecedores, pagar baixos salários, ter os piores

Conferência Europeia da Comunidade Alfresco

Já foi há quase quinze dias, mas julgo que ainda será relevante abordar a Conferência Europeia da Comunidade Alfresco, que decorreu em Barcelona no dia 22 de Abril. Com uma audiência de mais de 200 pessoas (a sala reservada estava cheia) vindas de vários pontos da Europa, este evento serviu para que muita gente desta comunidade se encontrasse pela primeira vez face a face. A Alfresco Inc. é uma empresa recente, que apostou em criar uma solução de gestão documental de topo de gama usando o modelo open-source . Considerando que a empresa, no seu terceiro ano de actividade, já atingiu o break-even , parece ter sido uma boa aposta. No arranque da conferência esteve John Powell, CEO da empresa, que falou um bocado sobre a excelente evolução da empresa e abordou a "guerra" entre o modelo de negócios proprietário e o modelo de código aberto. Exemplificou este conflito com o Microsoft SharePoint, que ele designou como "a morte da escolha", justificando o epíteto pelo facto

O que é uma POOL ?

Tenho andado a fazer implementações de mecanismos de pooling em Java 2 Enterprise Edition. Como me parece um conceito algo lato tentei a abordagem do dicionário. Alguns mostram que de facto a palavra é usada para muita coisa. A definição mais comum é "piscina". A que mais me agradou foi o que descobri na wikipedia , onde pooling é apresentada como uma técnica para guardar qualquer coisa que já não é necessária em determinado sitio (a que se chama pool ) com o objectivo de a usar quando necessário optimizando assim a utilização de recursos disponíveis. Partindo para a computação, existem vários tipos de pools: Thread Pool - Conjunto de threads livres que se vão adicionando a um fifo quando não necessárias e retirando quando se quiserem usar. Memory Pool - Conjunto de blocos de memória, todos da mesma dimensão, que se alocam inicialmente e usam à medida que necessário garantindo que o tempo de alocação de memória é constante e a fragmentação minima. Connect