[Gambas-devel] Release of gambas 1.9.23

Benoit Minisini gambas at ...1...
Mon Jan 2 02:21:29 CET 2006


Happy new year to everyone! (Well... for those who have the same calendar than 
me)

Here is a new release of the development version:

The main change in this version is the support for auto-increment and blob 
fields in the database component.

To create a serial field, use the 'db.Serial' constant as field datatype. And 
to create a blob field, use the 'db.Blob' constant.

Because of underlying database limits, you can only have one autoincrement 
field by table, and it must be the primary key.

Moreover, the blob support is not perfect: it uses SQL requests, and so wastes 
memory and CPU. Especially in the sqlite driver, which have many problems 
about that...

A blob field returns a Blob object, which have a Data property, that 
represents the blob data as a string. There is a Length property too, that 
returns the length of the blob data.

The returned Blob object is valid as long as you don't move or release the 
Result object it comes from.

Here is a little example:

	res = DB.Find("MyTable")
	PRINT res!BlobField.Data
	res!BlobField.Data = File.Load("picture.png")
	' The following is a shortcut for the previous line
	res!BlobField = File.Load("picture.png")

The following drivers were modified to support autoincrement fields and blobs:
 * MySQL
 * PostgreSQL
 * SQLite

ODBC and Firebird driver do not support it yet. I will post some explanation 
about what to do in the development mailing-list for Niggel, Andrea and 
Daniel

Otherwise, there are many other little changes you will see in the ChangeLog.

The more important is that now you can declare several local variables of the 
same datatype on the same line. This way:

	DIM i, j, k AS Integer

Maybe I should allow this syntax too:

	DIM i AS Integer, s, a AS String

I will see if it is possible...

So... try it and report the problems... :-)

-- 
Benoit Minisini





More information about the Devel mailing list