|
In that case. I just rewrote my original procedure into a function so you
can use it from a SELECT or VALUES statement directly from PHP.
https://gist.github.com/NielsLiisberg/d180d490a1e778a4a9530749498325ae
where the code is:
*-- Write a BLOB to IFS function*
*-- Note1: This also works for save files*
*-- Note2: This also compiles on vanilla systems without QSYSINCL
installed*
*-- Note3: I am using library QUSRSYS. I suggest you put it into your
own tool library*
*-- Simply paste this gist into ACS SQL and step through the example.*
*--*
*--*
*-- It is a cool example how far you can go with SQL: Have fun - *
*-- (C) Niels Liisberg 2025*
*--*
*-- This gist is distributed on an "as is" basis, without warranties *
*-- or conditions of any kind, either express or implied.*
*----------------------------------------------------------------------------------------------*
call qcmdexc ('crtsrcpf FILE(QTEMP/C) MBR(C)');
delete from qtemp.c;
*insert* into qtemp.c (srcdta) values
*-- Prototype warnings are chekked and OK *
*-- ('#include <sys/types.h>')*
*-- ('#include <sys/stat.h>')*
*-- ('#include <fcntl.h>')* ('#include <sqludf.h>')
,('int outFile;')
,('long pos = 1;')
,('long remains;')
,('long retlen;')
,('char buf [32760];')
,('long chunk = sizeof(buf); ')
,('int mode = 448; // mode_t mode = S_IRUSR | S_IWUSR | S_IXUSR;')
,(
'int opt = 106 ; // int opt = O_WRONLY | O_CREAT | O_TRUNC | O_CCSID ;')
,('int rc = sqludf_length(&MAIN.BUF, &remains);')
,('MAIN.NAME.DAT[MAIN.NAME.LEN] =0;')
,('outFile = open(MAIN.NAME.DAT, opt, mode, 1252);')
,('while (rc == 0 && remains > 0) {')
,(' rc = sqludf_substr(&MAIN.BUF, pos, chunk , buf , &retlen),')
,(' write (outFile , buf, retlen);')
,(' pos += chunk;')
,(' remains -= chunk;')
,('} ')
,('close(outFile);')
,('MAIN.RC = rc;')
;
create or *replace* function qusrsys.ifs_write_blob
(
payload *blob*(*2*g),
tofile *varchar*(*256*)
)
returns *int*
external action
modifies sql data
set option output=*print, commit=*ur, dbgview = *list
main: begin
declare buf *blob*(*2*G);
declare name *varchar*(*256*) ;
declare rc *int* default *0*;
*-- "buf" and "name" are in the C-code as MAIN.BUF and MAIN.NAME
<http://MAIN.NAME> * set buf = payload;
set name = tofile;
include qtemp/c(c);
return rc;
end;
*-- Use Case - return 0 on ok: *values qusrsys.ifs_write_blob (
payload *=>* SYSTOOLS.HTTPGETBLOB( url *=>* 'http://google.com'
, httpheader *=>* null),
tofile *=>* '/tmp/google.html'
);
On Tue, Jan 7, 2025 at 10:59 AM datil400 <datil400@xxxxxxxxx> wrote:
Thanks Birgita,PHP,
I know the RPG technique you are showing.
We are preparing a proof of concept to save a blob/cblob from SQL with
Java, etc. clients. That is the reason to try it from SQL and notreinvent
the wheel.SQFOVR
Best regards
Javier Mora
El lun, 6 ene 2025 a las 17:06, Birgitta Hauser (<Hauser@xxxxxxxxxxxxxxx
)
escribió:
Not sure why you do not want to use RPG?with
The following example generates an XML document and writes it directly
into the IFS (nothing else is needed).
You need to define a CLOB-File, and then fill the File Name
(MYXMLDOC_Name) with your IFS File Name, the Name Length (MYXMLDOC_NL)
the length of the name (without Blanks) and finally set the Operation
(MYXMLDOC_FO) to either SQFRD (=Read), SQFCRT (create a new file),
(Les(create a new file or replace a existing one) or SQFAPP (create a newfile
or add the data at the end of an existing file).
The data is directly written into the IFS with the SELECT ... INTO
Statement.
DCL-S MyXMLDoc SQLTYPE(XML_CLOB_File);
Clear MyXMLDoc;
MyXMLDoc_Name = '/home/Hauser/Examples/WriteXMLStaff.xml';
MyXMLDoc_NL = %Len(%Trim(MyXMLDoc_Name));
MyXMLDoc_FO = SQFOVR; //Replace if
exists
Exec SQL
Select XmlDocument
(xmlgroup(EmployeeNo as "PersNo",
Trim(Trim (FirstName) concat ' ' concat
Trim(Name)) as "PersName",
Address as "Street",
ZipCode as "ZipCode",
City as "City"
Order By City Desc, Name
Option Row "Employee"
Root "Staff"))
into :MyXMLDoc
From LobStaff;
If SQLCODE < *Zeros;
Dsply 'Error occured';
else;
Dsply 'XML Document generated';
EndIf;
*InLR = *On;
Mit freundlichen Grüßen / Best regards
Birgitta Hauser
Modernization – Education – Consulting on IBM i
Database and Software Architect
IBM Champion since 2020
"Shoot for the moon, even if you miss, you'll land among the stars."
https://www.ibm.com/docs/en/i/7.5?topic=is-ifs-write-ifs-write-binary-Brown)them
"If you think education is expensive, try ignorance." (Derek Bok)
"What is worse than training your staff and losing them? Not training
and keeping them!"datil400
"Train people well enough so they can leave, treat them well enough so
they don't want to. " (Richard Branson)
"Learning is experience … everything else is only information!" (Albert
Einstein)
-----Original Message-----
From: RPG400-L <rpg400-l-bounces@xxxxxxxxxxxxxxxxxx> On Behalf Of
Sent: Monday, 6 January 2025 14:11escribió:
To: RPG programming on IBM i <rpg400-l@xxxxxxxxxxxxxxxxxx>
Subject: Re: Save a BLOB only with SQL
Hello Daniel,
IFS_WRITE_BINARY is a stored procedure that cannot be called directily
from a SELECT statement, as in the case of 'get_blob_from_file'.
Will I have to create a user-defined function for this purpose?
Thanks
Javier Mora
El dom, 5 ene 2025 a las 22:07, Daniel Gross (<daniel@xxxxxxxx>)
Hi Javier,
i would try IFS_WRITE_BINARY.
->
postifs-write-utf8-procedures
HTH
Daniel
Am 05.01.2025 um 21:51 schrieb datil400 <datil400@xxxxxxxxx>:RPG?
Hi guys,
Is there any way to save a BLOB type in the IFS without having to
use
To load a BLOB you can use the function 'get_blob_from_file' but I
can't find the complementary one. Does this exist?
Best regards
--
Javier Mora
https://github.com/datil400
--
This is the RPG programming on IBM i (RPG400-L) mailing list To
aa message email: RPG400-L@xxxxxxxxxxxxxxxxxx To subscribe,related questions.
unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives at
https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription
--
This is the RPG programming on IBM i (RPG400-L) mailing list To post
unsubscribe,message email: RPG400-L@xxxxxxxxxxxxxxxxxx To subscribe,
oror change list options,--
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives at
https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription
related questions.
This is the RPG programming on IBM i (RPG400-L) mailing list To post a
message email: RPG400-L@xxxxxxxxxxxxxxxxxx To subscribe, unsubscribe,
relatedchange list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives at
https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription
relatedquestions.
--
This is the RPG programming on IBM i (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription
--questions.--
This is the RPG programming on IBM i (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related
questions.
This is the RPG programming on IBM i (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/rpg400-l.
Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related
questions.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.