473,385 Members | 1,877 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,385 software developers and data experts.

not in

Hi,

I'm trying to select some stored procedures' names who cannot be found into
the 'FilterProcedure' field of my table 'Lists':

select name
from sysobjects
where (type = 'p') and
(name not in
(select FilterProcedure from Lists
where FilterProcedure is not null))
order by name asc

'FilterProcedure' is defined as nvarchar(256), exactly as the 'name'
field of the 'sysobjects'. But the "not in" condition is never respected,
even if the intersection between the tables on the 'FilterProcedure' field
is not void.

Do you know what's wrong here?

Bogdan.
Jul 20 '05 #1
5 1228
[posted and mailed, please reply in news]

Bogdan Rechi (bo**********@hotmail.com) writes:
I'm trying to select some stored procedures' names who cannot be found
into the 'FilterProcedure' field of my table 'Lists':

select name
from sysobjects
where (type = 'p') and
(name not in
(select FilterProcedure from Lists
where FilterProcedure is not null))
order by name asc

'FilterProcedure' is defined as nvarchar(256), exactly as the 'name'
field of the 'sysobjects'. But the "not in" condition is never respected,
even if the intersection between the tables on the 'FilterProcedure' field
is not void.

Do you know what's wrong here?


Not really. Usually is a NULL value that trips people with IN / NOT IN,
but you seem to have catered for that.

Nevertheless, try NOT EXISTS instead:

SELECT name
FROM sysobjects o
WHERE type = 'P'
AND NOT EXISTS (SELECT *
FROM Lists l
WHERE l.FilterProcedure = o.name)
ORDER BY o.name ASC
--
Erland Sommarskog, SQL Server MVP, es****@sommarskog.se

Books Online for SQL Server SP3 at
http://www.microsoft.com/sql/techinf...2000/books.asp
Jul 20 '05 #2
>> Nevertheless, try NOT EXISTS instead:
Thank you for the tip but unfortunately it didn't work.

I've tried to walk the queries step by step, using 2 cursors:

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

declare curs cursor for
select name
from sysobjects
where type = 'p'
order by name asc

declare curs1 cursor for
select FilterProcedure FROM Lists
where FilterProcedure is not null

open curs

declare @ProcedureName nvarchar (256)
declare @ProcedureName1 nvarchar (256)

FETCH NEXT FROM curs into @ProcedureName
WHILE @@FETCH_STATUS = 0
begin
open curs1
FETCH NEXT FROM curs1 into @ProcedureName1
WHILE @@FETCH_STATUS = 0
begin
if (@ProcedureName1 = @ProcedureName) -- (!!!!)
print 'equal ' + @ProcedureName + ' and ' + @ProcedureName1
else
print 'not equal ' + @ProcedureName + ' and ' + @ProcedureName1
FETCH NEXT FROM curs1 into @ProcedureName1
end
close curs1
FETCH NEXT FROM curs into @ProcedureName
end

deallocate curs1

close curs
deallocate curs

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

The comparison at the line marked (!!!!) always returns false, even if the
values appear to be the same.(!?)

Now, if i would run high on arrogance i would say that it is an SQL-Server
obvious bug, but i rather have a poor experience with this system and i'm
still wondering about what's going on.

Bogdan.
Jul 20 '05 #3
On Thu, 2 Dec 2004 15:41:39 +0200, Bogdan Rechi wrote:

(snip)
The comparison at the line marked (!!!!) always returns false, even if the
values appear to be the same.(!?)

Now, if i would run high on arrogance i would say that it is an SQL-Server
obvious bug, but i rather have a poor experience with this system and i'm
still wondering about what's going on.


Hi Bogdan,

This might be caused by trailing blanks, unprintable characters or other
such nastiness. You might wish to check out the length of the two
variables, and you could check the UNICODE() value for each individual
character in both strings.

If that is not it, try if you can create a repro and post it here.

Best, Hugo
--

(Remove _NO_ and _SPAM_ to get my e-mail address)
Jul 20 '05 #4
>> This might be caused by trailing blanks, unprintable characters or other
Yes, it was a CRLF at the end of each record i've entered. The Query
Analizer was very confusing because it automatically trimmed the strings
while printing.

Thank you all for the answers.

Bogdan.

Jul 20 '05 #5
On Thu, 2 Dec 2004 16:38:35 +0200, Bogdan Rechi wrote:
This might be caused by trailing blanks, unprintable characters or other

Yes, it was a CRLF at the end of each record i've entered. The Query
Analizer was very confusing because it automatically trimmed the strings
while printing.


Hi Bogdan,

QA will trim CRLF if you use the Results in Grid option. The Results in
Text do show CRLF.

If you don't refer to trimming CRLF, but trimming after the first 256
characters, have a look at Tools / Options / Results / Maximum characters
per column.

Best, Hugo
--

(Remove _NO_ and _SPAM_ to get my e-mail address)
Jul 20 '05 #6

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...
1
by: CloudSolutions | last post by:
Introduction: For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
0
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 3 Apr 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 former...
0
by: ryjfgjl | last post by:
In our work, we often need to import Excel data into databases (such as MySQL, SQL Server, Oracle) for data analysis and processing. Usually, we use database tools like Navicat or the Excel import...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
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
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
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...

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.