Edit report at https://bugs.php.net/bug.php?id=24522&edit=1

 ID:                 24522
 Comment by:         cjrogala at gmail dot com
 Reported by:        cdcr440 at hotmail dot com
 Summary:            MSSQL: "Changed database context to" error when
                     running query
 Status:             Bogus
 Type:               Bug
 Package:            MSSQL related
 Operating System:   WinNT
 PHP Version:        4.3.1
 Block user comment: N
 Private report:     N

 New Comment:

I am an idiot.  Please disregard my post.


Previous Comments:
------------------------------------------------------------------------
[2011-07-10 18:34:22] cjrogala at gmail dot com

You may want to reopen this issue.  I am inserting data into MS SQL Server 
2008r2 and using PHP 5.2; and the same error occurs.  The positive is that the 
error did not prevent the data from being inserted into the database, but it 
did display the same error message.  I did not attempt to change the timeout 
since this is a much later version.  I also noticed this issue in a few 
different location on the web.  I am logging into the database as the sa and 
like I said, the data is making into the database; but the error still appears 
when validating the result of the query.  Unlike the previous post, I will not 
provide a credentials, but I know it's not a connection error since the data is 
getting into the database.  Here is my code:

$tsql = "USE littleliam
    INSERT INTO [littleliam].[dbo].[tbl_blogPosts]
           ([postText]
           ,[created]
           ,[createdBy]
           ,[approved])
     VALUES ('" .$postText ."', GETDATE(), " .$author .", " .$approvalStatus 
.")";

//Used to validate the query by running it in SQL Server Management studios
echo $tsql;
//Prepare and execute the statement.

mssql_select_db('littleliam');

$insertReview = mssql_query($tsql, $msServerLink);

if (!$res) {
    print("SQL statement failed with error:\n");
    print("   ".mssql_get_last_message()."\n");
} else {
    print("One data row inserted.\n");
}  

mssql_close($msServerLink); 


My connection script is:

$msServerLink = mssql_connect($db_server, $db_user, $db_pass);  

The only thing I could think of is selecting the database in the connect 
function.  Can a database be selected in the mssql_connect function?

------------------------------------------------------------------------
[2003-07-13 10:48:25] sni...@php.net

Temporarily closing. :)


------------------------------------------------------------------------
[2003-07-10 04:03:09] cdcr440 at hotmail dot com

Thank you very much for that. Unfortunately, I can't check that this fixes the 
problem because it's gone today and I didn't manage to find a query that fails. 
As I said it's unpredictable and appears/disappears regularly. I've increased 
the timeout and I'll see if the problem comes back again.

Sorry to have wasted your time, I think you can temporarily close this bug 
report.

------------------------------------------------------------------------
[2003-07-09 17:19:58] f...@php.net

This sounds like a timeout porblem.

You can use two php.ini settings to control the timeouts.

mssql.connect_timeout = 5
mssql.timeout = 60

These are default values in seconds. try to increase the second timeout value. 
(I'll make sure thes values makes it into the distributed versions of php.ini).

------------------------------------------------------------------------
[2003-07-09 07:52:15] cdcr440 at hotmail dot com

Thanks for looking into this.

The access rights should be sufficient because I tried several users including 
the sa user and the problem occured for all.

The database name doesn't include white spaces.

mssql.min_message_severity = 10 in my php.ini as I had attached but still see 
the message you say I should only see with mssql.min_message_severity = 0, 
maybe that's related to the problem. Could it be the result of the MSSQL module 
getting confused?

Even though "Changed database context to 'XXX'" isn't an error message, it 
appears when the query I try to run fails and the subsequent database 
selections fail with the same error.

Here is the shortest example that produces the error, sorry for the biggish 
query, this one is one that I know generates an error. It connects with the sa 
user that can access everything without restrictions:
<?

$config["sqlserver"]="192.168.101.3";
$config["sqluser"]="sa";
$config["sqlpassword"]="x";
$config["sqldatabase"]="XXX";

$theQuery="select top 15 ni.*   from NewsItem as ni, NewsItemStatus as nis, 
NewsStatus as ns
                                        where nis.NewsItemID=ni.ID 
                                        and ns.ID=nis.NewsStatusID 
                                        and lower(ns.Status) = lower('live')  
and (ni.ID in (select ni1.ID from NewsItem ni1 JOIN NewsItemNewsTagTable as 
nintt1 ON nintt1.NewsItemID=ni1.ID where  ni1.[Date] >= '09-Jun-2003' and  
nintt1.[Date] >= '09-Jun-2003' and  ni1.[Date] <= '09-Jul-2003' and  
nintt1.[Date] <= '09-Jul-2003' and  ( (lower(cast (Text as varchar(8000)))  
like '%chuan%' )or (lower(cast (BassoeComment as varchar(8000)))  like 
'%chuan%' )or (lower(cast (FirstParagraph as varchar(8000)))  like '%chuan%' 
)or (lower(cast (Title as varchar(8000)))  like '%chuan%' )or (lower(cast 
(nintt1.TagsCache as varchar(8000)))  like '%chuan%' ))) and ni.ID in (select 
ni1.ID from NewsItem ni1 JOIN NewsItemNewsTagTable as nintt1 ON 
nintt1.NewsItemID=ni1.ID where  ni1.[Date] >= '09-Jun-2003' and  nintt1.[Date] 
>= '09-Jun-2003' and  ni1.[Date] <= '09-Jul-2003' and  nintt1.[Date] <= 
'09-Jul-2003' and  ( (lower(cast (Text as varchar(8000)))  like '%hup%' )or 
(lower(cast (BassoeComment as varchar(8000)))  like '%hup%' )or (lower(cast 
(FirstParagraph as varchar(8000)))  like '%hup%' )or (lower(cast (Title as 
varchar(8000)))  like '%hup%' )or (lower(cast (nintt1.TagsCache as 
varchar(8000)))  like '%hup%' ))))  and ( ni.NewsTypeID=4 )  and ni.[Date] >= 
'09-Jun-2003' and ni.[Date] <= '09-Jul-2003' order by ni.[Date] desc, 
ni.[Timestamp] desc ";

print("Connecting to DB server... ");
$dbID = MSSQL_CONNECT($config["sqlserver"], $config["sqluser"], 
$config["sqlpassword"]);
if (!$dbID) {
        print("Error connecting to DB server.<br>\n");
} else {
        print("done.<br>\n");
}
print("Selecting database... ");
if (!mssql_select_db($config["sqldatabase"], $dbID)) {
        print("Error selecting database.<br>\n");
} else {
        print("done.<br>\n");
}
print("Running query... ");
$theResults = mssql_query($theQuery, $dbID); 
if (!$theResults) {
        print("Unable to run query:\n");
        print(mssql_get_last_message()."<br>\n");
} else {
        print("done.<br>\n");
}

?>

The output is as follows:
Connecting to DB server... done.
Selecting database... done.
Running query... Unable to run query: Changed database context to 'XXX'.

However, the query runs fine query analyzer with the same user (sa!), although 
slowly, so we can rule out a purely SQL problem.

However, if the query is reduced a bit, it doesn't fail:
select top 15 ni.*      from NewsItem as ni, NewsItemStatus as nis, NewsStatus 
as ns
                                        where nis.NewsItemID=ni.ID 
                                        and ns.ID=nis.NewsStatusID 
                                        and lower(ns.Status) = lower('live')  
and (ni.ID in (select ni1.ID from NewsItem ni1 JOIN NewsItemNewsTagTable as 
nintt1 ON nintt1.NewsItemID=ni1.ID where  ni1.[Date] >= '09-Jun-2003' and  
nintt1.[Date] >= '09-Jun-2003' and  ni1.[Date] <= '09-Jul-2003' and  
nintt1.[Date] <= '09-Jul-2003' and  ( (lower(cast (Text as varchar(8000)))  
like '%chuan%' )or (lower(cast (BassoeComment as varchar(8000)))  like 
'%chuan%' )or (lower(cast (FirstParagraph as varchar(8000)))  like '%chuan%' 
)or (lower(cast (Title as varchar(8000)))  like '%chuan%' )or (lower(cast 
(nintt1.TagsCache as varchar(8000)))  like '%chuan%' )))) and ( ni.NewsTypeID=4 
)  and ni.[Date] >= '09-Jun-2003' and ni.[Date] <= '09-Jul-2003' order by 
ni.[Date] desc, ni.[Timestamp] desc

So although it looks like a query problem, I remind you that both queries run 
fine through both query analyzer and the enterprise manager. Could it be a kind 
of time out problem since the second query (that succeeds) runs faster? I don't 
see timeout settings in the MSSQL configuration in php.ini. The script itself 
doesn't timeout and continues executing after the error.

The log I attached the other day was also showing that subsequent attempts to 
select the database to run another query would fail.

Does this help?

------------------------------------------------------------------------


The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at

    https://bugs.php.net/bug.php?id=24522


-- 
Edit this bug report at https://bugs.php.net/bug.php?id=24522&edit=1

Reply via email to