Thanks a lot!
It will do a clustered index scan. this is what it looks like.
StmtText
SELECT * from authors
WHERE
CONTAINS( *, 'keyworkd')
OR
au_lname LIKE '%keyworkd%'
(1 row(s) affected)
StmtText
----
|--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
[Expr1004]))
|--Nested Loops(Left Semi Join, WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
'%keyworkd%', NULL))OUTER REFERENCES
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
= [PROBE VALUE]))
|--Clustered Index
Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Table Spool
|--Remote Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
(6 row(s) affected)
I didn't think you were being serious before.
Basically it does a remote scan of the full text catalog (|--Remote
Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
against the authors table - scanning the au_id column using the auidind
index (this is a clustered index scan)
Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Table Spool
It then does a nested loop against the authors table using the join (Left
Semi Join, WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
and filters the results.
Put this query in query analyzer and hit ctrl - L
and you can see it for yourself.
Hilary Cotter
Looking for a SQL Server replication book?
http://www.nwsu.com/0974973602.html
Looking for a FAQ on Indexing Services/SQL FTS
http://www.indexserverfaq.com
"Matias Woloski" <woloski@.NOSPAMsion.com> wrote in message
news:OJYMB6lVFHA.1328@.tk2msftngp13.phx.gbl...
> Hillary, would you mind doing a small explanation on this post?
> Thanks a lot!
> It will do a clustered index scan. this is what it looks like.
>
> StmtText
> ----
--
> --
> SELECT * from authors
> WHERE
> CONTAINS( *, 'keyworkd')
> OR
> au_lname LIKE '%keyworkd%'
> (1 row(s) affected)
> StmtText
> ----
--
> ----
--
> --
> |--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> [Expr1004]))
> |--Nested Loops(Left Semi Join, WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> '%keyworkd%', NULL))OUTER REFERENCES
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
DEFINE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> = [PROBE VALUE]))
> |--Clustered Index
> Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> |--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> |--Table Spool
> |--Remote Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> (6 row(s) affected)
>
>
|||Thanks Hilary for introducing me into this.
Now, I see the execution plan for this query and I see that 87% of the query
is the remote scan (contains).
I was concerned about the perf impact of having CONTAINS and LIKE both
together and it seems that is minimal.
What if I have 100k records? How the clustered index (like expr) would
perform? How compared to a query which only does a remote scan?
Thanks again for your help,
Matias
"Hilary Cotter" <hilary.cotter@.gmail.com> wrote in message
news:uHajidvVFHA.2768@.tk2msftngp13.phx.gbl...
>I didn't think you were being serious before.
> Basically it does a remote scan of the full text catalog (|--Remote
> Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> against the authors table - scanning the au_id column using the auidind
> index (this is a clustered index scan)
> Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> |--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> |--Table Spool
> It then does a nested loop against the authors table using the join (Left
> Semi Join, WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
> and filters the results.
> Put this query in query analyzer and hit ctrl - L
> and you can see it for yourself.
>
> --
> Hilary Cotter
> Looking for a SQL Server replication book?
> http://www.nwsu.com/0974973602.html
> Looking for a FAQ on Indexing Services/SQL FTS
> http://www.indexserverfaq.com
> "Matias Woloski" <woloski@.NOSPAMsion.com> wrote in message
> news:OJYMB6lVFHA.1328@.tk2msftngp13.phx.gbl...
> --
> --
> --
> DEFINE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
>
>
|||The nested loop is changed to a merge join
|--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
[Expr1004]))
|--Merge Join(Left Semi Join,
MERGE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
RESIDUAL
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
like([fulltext].[charcol], '%keyworkd%', NULL))
|--Clustered Index
Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Sort(ORDER BY
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Remote Scan(OBJECT
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
(5 row(s) affected)
Hilary Cotter
Looking for a SQL Server replication book?
http://www.nwsu.com/0974973602.html
Looking for a FAQ on Indexing Services/SQL FTS
http://www.indexserverfaq.com
"Matias Woloski" <woloski@.NOSPAMsion.com> wrote in message
news:uZPS3KxVFHA.2496@.TK2MSFTNGP10.phx.gbl...
> Thanks Hilary for introducing me into this.
> Now, I see the execution plan for this query and I see that 87% of the
query[vbcol=seagreen]
> is the remote scan (contains).
> I was concerned about the perf impact of having CONTAINS and LIKE both
> together and it seems that is minimal.
> What if I have 100k records? How the clustered index (like expr) would
> perform? How compared to a query which only does a remote scan?
> Thanks again for your help,
> Matias
>
> "Hilary Cotter" <hilary.cotter@.gmail.com> wrote in message
> news:uHajidvVFHA.2768@.tk2msftngp13.phx.gbl...
join[vbcol=seagreen]
(Left[vbcol=seagreen]
-[vbcol=seagreen]
-[vbcol=seagreen]
-[vbcol=seagreen]
WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
|--Filter(WHERE
data:image/s3,"s3://crabby-images/4166f/4166fb84b681968ec20f73802bd5a1380198f1c6" alt="Not happy"
>
No comments:
Post a Comment