473,406 Members | 2,390 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,406 software developers and data experts.

PHP and DB2

Hi-

I'm getting some rather strange behavior with PHP4 on Debian Linux
accessing a DB2 V8.1 box on AIX. I've recompiled PHP "--with-ibm-db2"
support. I'm able to connect to the database just fine, but when I
attempt to select data from a table "WITH UR", I get the following
error:

Warning: odbc_exec(): SQL error: [IBM][CLI Driver][DB2/AIX64] SQL0104N
An unexpected token "FOR UPDATE" was found following "naptime desc
with ur". Expected tokens may include: "<space>". SQLSTATE=42601 , SQL
state 42601 in SQLExecDirect in /var/www/recent.php on line 62

Here's the PHP code snippet I'm running:

--- Start Code ---
//Connect to database
$conn = odbc_connect($dsn,$user,$passwd,SQL_CUR_USE_DRIVER );

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats where group
by snaptime having count(*) > 5 order by snaptime desc with ur";

//Execute SQL
$resultset = odbc_Exec( $conn, $SQLSTRING); <-- Error occurs here.
--- End Code ---
It seems that for some reason, "FOR UPDATE" is being automagically
appended to my SQL String. I want to run with Uncommitted Read to
prevent lock waits on the stats table, which is being constantly
updated.

If anybody has any insights, I'd greatly appreciate it.

Thanks,
Todd
Nov 12 '05 #1
3 4689
Correction- The SQL should be:

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats group by
snaptime having count(*) > 5 order by snaptime desc with ur";

Thanks,
Todd

to********@yahoo.com (Todd McNeill) wrote in message news:<9c*************************@posting.google.c om>...
Hi-

I'm getting some rather strange behavior with PHP4 on Debian Linux
accessing a DB2 V8.1 box on AIX. I've recompiled PHP "--with-ibm-db2"
support. I'm able to connect to the database just fine, but when I
attempt to select data from a table "WITH UR", I get the following
error:

Warning: odbc_exec(): SQL error: [IBM][CLI Driver][DB2/AIX64] SQL0104N
An unexpected token "FOR UPDATE" was found following "naptime desc
with ur". Expected tokens may include: "<space>". SQLSTATE=42601 , SQL
state 42601 in SQLExecDirect in /var/www/recent.php on line 62

Here's the PHP code snippet I'm running:

--- Start Code ---
//Connect to database
$conn = odbc_connect($dsn,$user,$passwd,SQL_CUR_USE_DRIVER );

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats where group
by snaptime having count(*) > 5 order by snaptime desc with ur";

//Execute SQL
$resultset = odbc_Exec( $conn, $SQLSTRING); <-- Error occurs here.
--- End Code ---
It seems that for some reason, "FOR UPDATE" is being automagically
appended to my SQL String. I want to run with Uncommitted Read to
prevent lock waits on the stats table, which is being constantly
updated.

If anybody has any insights, I'd greatly appreciate it.

Thanks,
Todd

Nov 12 '05 #2
Todd McNeill wrote:
Correction- The SQL should be:

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats group by
snaptime having count(*) > 5 order by snaptime desc with ur";

Thanks,
Todd

to********@yahoo.com (Todd McNeill) wrote in message news:<9c*************************@posting.google.c om>...
Hi-

I'm getting some rather strange behavior with PHP4 on Debian Linux
accessing a DB2 V8.1 box on AIX. I've recompiled PHP "--with-ibm-db2"
support. I'm able to connect to the database just fine, but when I
attempt to select data from a table "WITH UR", I get the following
error:

Warning: odbc_exec(): SQL error: [IBM][CLI Driver][DB2/AIX64] SQL0104N
An unexpected token "FOR UPDATE" was found following "naptime desc
with ur". Expected tokens may include: "<space>". SQLSTATE=42601 , SQL
state 42601 in SQLExecDirect in /var/www/recent.php on line 62

Here's the PHP code snippet I'm running:

--- Start Code ---
//Connect to database
$conn = odbc_connect($dsn,$user,$passwd,SQL_CUR_USE_DRIVER );

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats where group
by snaptime having count(*) > 5 order by snaptime desc with ur";

//Execute SQL
$resultset = odbc_Exec( $conn, $SQLSTRING); <-- Error occurs here.
--- End Code ---
It seems that for some reason, "FOR UPDATE" is being automagically
appended to my SQL String. I want to run with Uncommitted Read to
prevent lock waits on the stats table, which is being constantly
updated.

If anybody has any insights, I'd greatly appreciate it.

Thanks,
Todd


My guess is that PHP is automatically set to a conservative isolation
level, which is why it tries to append "FOR UPDATE" to SELECT
statements. (I've seen this behaviour too.)

A user-contributed note to the odbc_exec function
(http://ca.php.net/manual/en/function.odbc-exec.php) suggests tacking on
"FOR READ ONLY" to the SELECT statement to prevent PHP from adding "FOR
UPDATE". So if you try:

$SQLSTRING="select snaptime, count(*) from $schema.stats where group
by snaptime having count(*) > 5 order by snaptime desc FOR READ ONLY
with ur";

-- this should work; I recreated your problem with a local database and
resolved it by adding the FOR READ ONLY clause in the appropriate spot.

Note that use of the FOR READ ONLY clause is generally recommended for
improving performance of queries that won't be used to perform updates
(http://publib.boulder.ibm.com/infoce.../r0000879.htm).
I suspect that if you specifiy FOR READ ONLY, you probably won't need to
specify WITH UR -- but that's just a suspicion.

Dan
Nov 12 '05 #3
Todd McNeill wrote:
Correction- The SQL should be:

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats group by
snaptime having count(*) > 5 order by snaptime desc with ur";

Thanks,
Todd

to********@yahoo.com (Todd McNeill) wrote in message news:<9c*************************@posting.google.c om>...
Hi-

I'm getting some rather strange behavior with PHP4 on Debian Linux
accessing a DB2 V8.1 box on AIX. I've recompiled PHP "--with-ibm-db2"
support. I'm able to connect to the database just fine, but when I
attempt to select data from a table "WITH UR", I get the following
error:

Warning: odbc_exec(): SQL error: [IBM][CLI Driver][DB2/AIX64] SQL0104N
An unexpected token "FOR UPDATE" was found following "naptime desc
with ur". Expected tokens may include: "<space>". SQLSTATE=42601 , SQL
state 42601 in SQLExecDirect in /var/www/recent.php on line 62

Here's the PHP code snippet I'm running:

--- Start Code ---
//Connect to database
$conn = odbc_connect($dsn,$user,$passwd,SQL_CUR_USE_DRIVER );

//Build SQL String
$SQLSTRING="select snaptime, count(*) from $schema.stats where group
by snaptime having count(*) > 5 order by snaptime desc with ur";

//Execute SQL
$resultset = odbc_Exec( $conn, $SQLSTRING); <-- Error occurs here.
--- End Code ---
It seems that for some reason, "FOR UPDATE" is being automagically
appended to my SQL String. I want to run with Uncommitted Read to
prevent lock waits on the stats table, which is being constantly
updated.

If anybody has any insights, I'd greatly appreciate it.

Thanks,
Todd


My guess is that PHP is automatically set to a conservative isolation
level, which is why it tries to append "FOR UPDATE" to SELECT
statements. (I've seen this behaviour too.)

A user-contributed note to the odbc_exec function
(http://ca.php.net/manual/en/function.odbc-exec.php) suggests tacking on
"FOR READ ONLY" to the SELECT statement to prevent PHP from adding "FOR
UPDATE". So if you try:

$SQLSTRING="select snaptime, count(*) from $schema.stats where group
by snaptime having count(*) > 5 order by snaptime desc FOR READ ONLY
with ur";

-- this should work; I recreated your problem with a local database and
resolved it by adding the FOR READ ONLY clause in the appropriate spot.

Note that use of the FOR READ ONLY clause is generally recommended for
improving performance of queries that won't be used to perform updates
(http://publib.boulder.ibm.com/infoce.../r0000879.htm).
I suspect that if you specifiy FOR READ ONLY, you probably won't need to
specify WITH UR -- but that's just a suspicion.

Dan
Nov 12 '05 #4

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

3
by: William C. White | last post by:
Does anyone know of a way to use PHP /w Authorize.net AIM without using cURL? Our website is hosted on a shared drive and the webhost company doesn't installed additional software (such as cURL)...
2
by: Albert Ahtenberg | last post by:
Hello, I don't know if it is only me but I was sure that header("Location:url") redirects the browser instantly to URL, or at least stops the execution of the code. But appearantely it continues...
3
by: James | last post by:
Hi, I have a form with 2 fields. 'A' 'B' The user completes one of the fields and the form is submitted. On the results page I want to run a query, but this will change subject to which...
0
by: Ollivier Robert | last post by:
Hello, I'm trying to link PHP with Oracle 9.2.0/OCI8 with gcc 3.2.3 on a Solaris9 system. The link succeeds but everytime I try to run php, I get a SEGV from inside the libcnltsh.so library. ...
1
by: Richard Galli | last post by:
I want viewers to compare state laws on a single subject. Imagine a three-column table with a drop-down box on the top. A viewer selects a state from the list, and that state's text fills the...
4
by: Albert Ahtenberg | last post by:
Hello, I have two questions. 1. When the user presses the back button and returns to a form he filled the form is reseted. How do I leave there the values he inserted? 2. When the...
1
by: inderjit S Gabrie | last post by:
Hi all Here is the scenerio ...is it possibly to do this... i am getting valid course dates output on to a web which i have designed ....all is okay so far , look at the following web url ...
2
by: Jack | last post by:
Hi All, What is the PHP equivilent of Oracle bind variables in a SQL statement, e.g. select x from y where z=:parameter Which in asp/jsp would be followed by some statements to bind a value...
3
by: Sandwick | last post by:
I am trying to change the size of a drawing so they are all 3x3. the script below is what i was trying to use to cut it in half ... I get errors. I can display the normal picture but not the...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.