質問

I have enabled sql profiler and identified several queries that are taking a long time to execute.

For example:

Select A from table_A where B = 2

My question is, based on above query, do I create indexes on column A or B? or A and B?

役に立ちましたか?

解決

Index on B including column A. The where can use a seek on B while still returning A.

他のヒント

Your index should be on B since that's what is in your condition. You might benefit from just trying out all the ways and looking at the resulting execution plans.

I would create an index on column B because that is what sql server is doing the comparison on. Afterwards I would run the profiler again to see if adding the index negatively impacts other queries.

Create seperate indexes on B and A. Creating index on A is to avoid KEY LOOKUP.

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top