Latest Publications

REALbasic, the iPhone and Valentina DB

There is an interesting conversation taking place over on Bob Keeney’s blog regarding REALbasic and the iPhone.

Paradigma Software has had a Valentina Client for the iPhone for almost a year, and while its seen some use, I often feel that just having it has helped bring new customers to use Valentina DB who have no intention of using Valentina for the iPhone.

A lot of folks commenting know REAL Software – the company – very well. Maybe too well. Supporting the iPhone sounds like a monumental task, and you’ve been waiting a long, long time for Cocoa support and that’s likely come at some cost. You don’t want to go through that with iPhone support.

But at the end of the day, a company closely associated with the Mac – and therefore Apple – must have an iPhone strategy, or they will see their customers move development to a tool that supports both.  Runtime Revolution has already announced a mobile strategy for Runrev and in preparation for a mobile strategy. Unity, a popular 3D development system – dropped their basic product to free but charges a professional level of pricing for iPhone compatibility (they use Mono on desktops and generate Objective-C based projects for compilation to iPhone).

So I have to agree with Geoff Perlman of REAL Software – REAL must have a significant iPhone strategy or they will not be able to evolve with the market.

Kem Tekinay: What I’ve learned about Valentina

In jumping back into Valentina, I’ve learned a number of things over the past few days that I thought I’d share. In no particular order…

- Valentina support (particularly Ruslan) has to be the most responsive support of any company in any country, ever.

- Valentina is fast. I mean, really fast. Using a flat-file database of 7 fields and 5 million+ records, and comparing it to other solutions like MySQL, PostgreSQL, SQLite and FileMaker Pro, Valentina beats them all in every test I can come up with. The only thing that is even close to the same range is MySQL, and only in some tests.

(more…)

[NEW] REGEX_REPLACE() function.

In 4.5.1 release we have add a new REGEX_REPLACE() function  to Valentina Expresions, which can be used in Table Methods, SQL and therefore, in Reports.

Up to now, we was able to do searches with the help of REGEX operator:

… WHERE fld REGEX ‘ab.[cdf]*’

New function brings the awesome power of REGEX to manipulate by strings stored in the database! Now we can not only search using REGEX, but modify strings! You can do that in the

  • SELECT EXPR, …
  • UPDATE TABLE T SET fld = EXPR

where EXPR is REGEX_REPLACE() function or contains it as a part.

Read details about this function here.

FindContains() speed improved x10 times

Kem Tekinay have found that FindContains is not fast enough. We was able speed up this place x10 times. Indexed search on table with 7 million rows have go down from 46 sec to 4.6 sec.

You can get this using

  • API – VField.FindContains()
  • SQL –  WHERE LOCATE( “what”, fld ) <> 0

NEW 2 video lessons about BarCodes and MailMerge with Valentina Reports

We have upload 2 new video lessons about Valentina reports:

http://valentina-db.com/dokuwiki/doku.php?id=valentina:video:vspro:vspro

Working with big vDatabases

Valentina is a perfect choice to work with a big data. It employs vertical storage approach. It means – each column has own virtual file to be stored in. Most of db vendors use a horizontal storage – it stores a table data in record-by-record manner.

There are some vertical storage advantages:

(more…)

V4RB.rbx plugin now contains COCOA version.

This means that you should be able to use V4RB 4.5 in your cocoa applications made with REALbasic.

VCursor Now Can UpdateRecord() of JOINs !!!

It is well known that Valentina offers to developer a very reach ADK API (about 1000 methods) in contrast to poor API of most dbs (e.g. near to 25 in mySQL).

One of nice feature is the ability to use VCursor class methods to MODIFY records of ServerSide & ReadWrite cursor. But for years we did have limit here: cursor can be ReadWrite only for single table SELECT. In the release 4.5 we remove this limitation! Now you can do UpdateRecord() and DropRecord() for cursors built over INNER JOIN of N tables!

(more…)

Valentina Server 64-bit.

We are happy to introduce, in the release 4.5,  the result of our 8 months efforts – Valentina Server 64 bit for 3 platforms (win, mac, linux)!

(more…)

Deprecated Convert_1_2() feature.

Also we are dropping Convert_1_2() feature of Valentina engine from 2.0 version to allow developers convert existed v1 databases. If somebody yet need convert v1 database to 2.0 format, he should use at first v4.3 for this task.

This function is removed from all Valentina ADKs and VStudio, DLL of VDK V1 engine  is removed from the vcomponents folder.