Jump to content

Database Connectivity Toolkit Multi Row Insert


Recommended Posts

Posted

Hi all. I recently got the Database Connectivity Toolkit (DBCT) on LabVIEW 2016 and I'm trying to insert multiple rows into a database.

Using a sine signal input I attempted to insert 50 rows in one iteration, but every method I tried returned 50 values in one row. Using the end of line constant and array to spreadsheet string, returned what looked like 50 rows, but when I queried "SELECT COUNT(*) FROM.." the no of rows was equal to the number of iterations.

On another forum post, someone suggested it is not possible to insert multiple rows using the DBCT. Can anyone confirm this?

I have written some code which allows me to insert 3 rows in one iteration, under a single connection. However, this method is very tedious and wouldn't work for large amounts of data.

 

DB Connectivity (Multi Row Insert).png

 

Can anyone think of a better way to do this?

 

Thanks in advance,

 

Lisa

Posted

I would use the low level SQL syntax to do this...if the database supports it.

INSERT INTO test1 (Column1,Column2) VALUES(1,2),(3,4),(5,6);

I've stopped using NI's DB toolkit, instead I use the LabSQL ADO drivers wrapped in my own driver.
This is much faster.

I've attached my version

DB_Export.zip

  • Like 1
Posted
16 hours ago, MikaelH said:

I've stopped using NI's DB toolkit, instead I use the LabSQL ADO drivers wrapped in my own driver.

This is much faster.

Do you have anything indicating how much of a speed difference there is?

Posted (edited)

Hi Mikael, thank your suggestion and help!

I managed to connect to my db using open and close connection invoke nodes and execute a query using ADO execute. Thanks very much indeed. My only question: do you know if ADO compatible with Linux Real-Time cRIO?

Thanks for your time, it is much appreciated.

Lisa

 

 

Edited by lisam
Posted

damn, that seemed like a great method. Do you know of any method that will work on linux?

I've been following a tutorial for LabVIEW to PostgreSQL for Linux RT using the system exec VI, (https://decibel.ni.com/content/docs/DOC-30308) which works but it opens and closes the connection every time data is inserted (unless I string all the values together first - which isn't very efficient). Another suggestion is using the Call Library Function Node - but I can't find any examples with a PostgreSQL API.

 

  • 2 weeks later...
Posted (edited)
On 1-11-2016 at 2:01 PM, lisam said:

Hi Mikael, thank your suggestion and help!

I managed to connect to my db using open and close connection invoke nodes and execute a query using ADO execute. Thanks very much indeed. My only question: do you know if ADO compatible with Linux Real-Time cRIO?

Thanks for your time, it is much appreciated.

Lisa

Of course not! ADO stands for ActivX Database Objects and ActiveX is a Windows only technology.

Depending of the actual database server you want to access there are several possibilities but not all of them are readily doable in LabVIEW for Linux.

If your database driver is implementing the whole communication directly in the LabVIEW VI level such as the MySQL driver here which access the MySQL server directly through TCP/IP communication, then you are fine.

Accessing the unixODBC driver is another possibility which keeps the LabVIEW part independent of the actual database driver implementation. This project does provide such a LabVIEW library however, it is not always easy to get a working ODBC driver for a specific database server. Microsoft officially supports Linux clients with their latest SQL server but I have not tried that at all, and if you talk about the NI Linux realtime targets an additional problem is the architecture (ARM based for the low cost targets and x64 based for the high end targets) and the fact that NI Linux RT isn't a normal standard Linux system but in several aspects a slimmed down Linux kernel that some precompiled binaries may not work on, and to expect Microsoft to give you the source code of their SQL server libraries to compile your own binaries for a specific target is of course pretty hopeless.

Edited by rolfk

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.