Solved

Non-visual data access

Posted on 2004-09-22
9
204 Views
Last Modified: 2010-04-05
I have just begun working with SQL and Delphi and am trying to read up on it, but everything wants me to use the VCL.

I have a simple task I want to complete, and don't want any visual components to do it.

I pull data from an LDAP server and store it all in a TList.
I then want to take the data in my tlist and write it to fields in a SQL table.

Then i'll want another function to read the data that is there, store it back in my TList so I can do what I need to do with it there.

I know what connection string i want to use, etc... I just can't seem to figure out how to read/write data in my sql table without using DBGrid or anything visual.

Any help?
0
Comment
Question by:gwarguitar
9 Comments
 
LVL 13

Expert Comment

by:BlackTigerX
ID: 12123872
you can either drop some ADOConnection and ADOQuery to your form, those are not visual components, but you can modify it's properties in the Object Inspector
or you can create those dinamically, something like this:

var
  myADOConn:TADOConnection;
  myADOQuery:TADOQuery;
const
  CONN_STR = 'Provider=SQLOLEDB.1;Password=%s;Persist Security Info=True;User ID=%s;Initial Catalog=%s;Data Source=%s';
begin
  myADOConn:=TADOConnection.Create(nil);
  myADOQuery:=TADOQuery.Create(nil);
  try
    myADOConn.LoginPrompt:=False;
    myADOConn.Mode:=cmShareDenyNone;
    myADOConn.ConnectionString:=Format(CONN_STR, [
           'DBPassword', 'DBUser', 'DBDatabase', 'DBServer']);
    myADOQuery.Connection:=myADOConn;
    myADOQuery.SQL.Text:='insert into table, blablabla';
    myADOQuery.ExecSQL;
  finally
    myADOConn.Connected:=False;
    myADOQuery.Free;
    myADOConn.Free
  end
end;
0
 
LVL 13

Expert Comment

by:BlackTigerX
ID: 12123919
if you drop the components in the form, all you need from this code is:

myADOQuery.SQL.Text:='insert into table, blablabla'; //your query here
    myADOQuery.ExecSQL;

the rest you can change it in the Object Inspector
0
 

Author Comment

by:gwarguitar
ID: 12123945
yeah, i don't mind the components, i just want to pull the data non visually.

what about reading to my tlist?
0
 

Author Comment

by:gwarguitar
ID: 12124138
here, i'll give a more specific example...

type
  PUserInfo = ^TUserInfo;
  TUserInfo = record
    first_name : ShortString;
    last_name  : ShortString;
  end;

that's my tlist

and the fields in my db..

 [FirstName] [varchar] (35) NOT NULL ,
 [LastName] [varchar] (35) NOT NULL

there are more fields, but that will give me an idea.

so how do i loop through every item in my tlist, adding data to the db where appropriate. then the other way around?


0
What Security Threats Are You Missing?

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

 
LVL 13

Assisted Solution

by:BlackTigerX
BlackTigerX earned 125 total points
ID: 12124293
var UserInfo:TUserInfo;
begin
    for X:=0 to myList.Count-1 do //myList is your list of pointers...
    begin
      UserInfo:=TUserInfo(myList.Items[X]^); //get the user information out of the list
      myADOQuery.SQL.Text:='insert into your table (FirstName, LastName) '+
      'values ('+QuotedStr(UserInfo.first_name)+','+QuotedStr(UserInfo.last_name)+')';
      myADOQuery.ExecSQL
    end

//myADOQuery is the variable I showed you in the other example
0
 
LVL 13

Expert Comment

by:BlackTigerX
ID: 12124300
this part:

myADOQuery.SQL.Text:='insert into your table (FirstName, LastName) '+

needs to be whatever the name of your table is:

myADOQuery.SQL.Text:='insert into YOURTABLENAMEHERE (FirstName, LastName) '+
0
 
LVL 12

Expert Comment

by:esoftbg
ID: 12124371
> .... I just can't seem to figure out how to read/write data in my sql table without using DBGrid or anything visual.

Ofcourse you don't need DBGrid to read/write data (Data is reading and writing by TADOQuery, TADOTAble .... TQuery, TTable .... ): DBGrid is for visualization, editing and / or inserting data ... If you don't need visualization, editing and / or inserting data you may work without DBGrid and without anything visual.
0
 

Author Comment

by:gwarguitar
ID: 12126625
woohoo! that works..

what about reading to my tlist? what statement would i use for that?
0
 
LVL 17

Accepted Solution

by:
geobul earned 125 total points
ID: 12130503

  ADOQuery1.Close;
  ADOQuery1.SQL.Clear;
  ADOQuery1.SQL.Add ('SELECT * FROM tablename');
  ADOQuery1.Open; // get dataset
  while not ADOQuery1.EOF do begin // loop dataset
    ui.first_name := ADOQuery1.FieldByName('FirstName').AsString; // read fields in a record
    ui.last_name := ADOQuery1.FieldByName('LastName').AsString;
    List1.Add(ui); // add the record to the list
    ADOQuery1.Next;
  end;
  ADOQuery1.Close;

Regards, Geo
0

Featured Post

Find Ransomware Secrets With All-Source Analysis

Ransomware has become a major concern for organizations; its prevalence has grown due to past successes achieved by threat actors. While each ransomware variant is different, we’ve seen some common tactics and trends used among the authors of the malware.

Join & Write a Comment

Introduction Raise your hands if you were as upset with FireMonkey as I was when I discovered that there was no TListview.  I use TListView in almost all of my applications I've written, and I was not going to compromise by resorting to TStringGrid…
In my programming career I have only very rarely run into situations where operator overloading would be of any use in my work.  Normally those situations involved math with either overly large numbers (hundreds of thousands of digits or accuracy re…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
This video explains how to create simple products associated to Magento configurable product and offers fast way of their generation with Store Manager for Magento tool.

744 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now