How to find if a column is referenced in a computed column? Unicorn Meta Zoo #1: Why another podcast? Announcing the arrival of Valued Associate #679: Cesar ManaraWhy does OBJECT_ID return NULL in a computed column?Deadlocks on primary key row locks race condition with temporal tablesMulti-schema, multi-tenant databases - data isolation through composite primary keyshow to find the database context of the last sql statement?How to find Stored Procedures With Recompile?Validate data between two large tablesHow to create a Hash Computed Column for Many Columns?HashBytes Computed Column: Exclude ColumnSQL Server: Covering indexes including all columns?Mimicking cascading foreign key referencing system table

Multi tool use
Multi tool use

Why didn't the Space Shuttle bounce back into space as many times as possible so as to lose a lot of kinetic energy up there?

"My boss was furious with me and I have been fired" vs. "My boss was furious with me and I was fired"

Can a level 2 Warlock take one level in rogue, then continue advancing as a warlock?

Is there any pythonic way to find average of specific tuple elements in array?

My bank got bought out, am I now going to have to start filing tax returns in a different state?

What was Apollo 13's "Little Jolt" after MECO?

Unable to completely uninstall Zoom meeting app

Co-worker works way more than he should

Did the Roman Empire have penal colonies?

Why do games have consumables?

Can you stand up from being prone using Skirmisher outside of your turn?

What makes accurate emulation of old systems a difficult task?

What is the term for a person whose job is to place products on shelves in stores?

All ASCII characters with a given bit count

Retract an already submitted recommendation letter (written for an undergrad student)

What is the best way to deal with NPC-NPC combat?

A strange hotel

A Paper Record is What I Hamper

How exactly does Hawking radiation decrease the mass of black holes?

What's the difference between using dependency injection with a container and using a service locator?

How to keep bees out of canned beverages?

finding a tangent line to a parabola

Can I criticise the more senior developers around me for not writing clean code?

Scheduling based problem



How to find if a column is referenced in a computed column?



Unicorn Meta Zoo #1: Why another podcast?
Announcing the arrival of Valued Associate #679: Cesar ManaraWhy does OBJECT_ID return NULL in a computed column?Deadlocks on primary key row locks race condition with temporal tablesMulti-schema, multi-tenant databases - data isolation through composite primary keyshow to find the database context of the last sql statement?How to find Stored Procedures With Recompile?Validate data between two large tablesHow to create a Hash Computed Column for Many Columns?HashBytes Computed Column: Exclude ColumnSQL Server: Covering indexes including all columns?Mimicking cascading foreign key referencing system table



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








3















I'm trying to mass retype columns. That means first dropping and recreating any constraints they are part of.



I found columns referenced by these constraints



  • Foreign Keys,

  • Primary Keys,

  • Indexes,

  • Check constraints,

  • Rules,

  • Default constraints.

But I cannot find Computed columns.



I've looked into INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE, but it doesn't include Computed Columns.



There is also sys.computed_columns which shows definition, but doesn't list columns in searchable manner.



Is there anywhere else I can look? If SQL Server can figure out the dependence, I thought I would be able to as well.










share|improve this question

















  • 1





    Did you look into sys.dm_sql_referenced_entities?

    – Scott Hodgin
    1 hour ago











  • Yes, that's not it. But you pointed me in the right direction and I found it in sys.sql_expression_dependencies.

    – Zikato
    1 hour ago

















3















I'm trying to mass retype columns. That means first dropping and recreating any constraints they are part of.



I found columns referenced by these constraints



  • Foreign Keys,

  • Primary Keys,

  • Indexes,

  • Check constraints,

  • Rules,

  • Default constraints.

But I cannot find Computed columns.



I've looked into INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE, but it doesn't include Computed Columns.



There is also sys.computed_columns which shows definition, but doesn't list columns in searchable manner.



Is there anywhere else I can look? If SQL Server can figure out the dependence, I thought I would be able to as well.










share|improve this question

















  • 1





    Did you look into sys.dm_sql_referenced_entities?

    – Scott Hodgin
    1 hour ago











  • Yes, that's not it. But you pointed me in the right direction and I found it in sys.sql_expression_dependencies.

    – Zikato
    1 hour ago













3












3








3








I'm trying to mass retype columns. That means first dropping and recreating any constraints they are part of.



I found columns referenced by these constraints



  • Foreign Keys,

  • Primary Keys,

  • Indexes,

  • Check constraints,

  • Rules,

  • Default constraints.

But I cannot find Computed columns.



I've looked into INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE, but it doesn't include Computed Columns.



There is also sys.computed_columns which shows definition, but doesn't list columns in searchable manner.



Is there anywhere else I can look? If SQL Server can figure out the dependence, I thought I would be able to as well.










share|improve this question














I'm trying to mass retype columns. That means first dropping and recreating any constraints they are part of.



I found columns referenced by these constraints



  • Foreign Keys,

  • Primary Keys,

  • Indexes,

  • Check constraints,

  • Rules,

  • Default constraints.

But I cannot find Computed columns.



I've looked into INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE, but it doesn't include Computed Columns.



There is also sys.computed_columns which shows definition, but doesn't list columns in searchable manner.



Is there anywhere else I can look? If SQL Server can figure out the dependence, I thought I would be able to as well.







t-sql sql-server-2016 dmv system-tables






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked 4 hours ago









ZikatoZikato

23918




23918







  • 1





    Did you look into sys.dm_sql_referenced_entities?

    – Scott Hodgin
    1 hour ago











  • Yes, that's not it. But you pointed me in the right direction and I found it in sys.sql_expression_dependencies.

    – Zikato
    1 hour ago












  • 1





    Did you look into sys.dm_sql_referenced_entities?

    – Scott Hodgin
    1 hour ago











  • Yes, that's not it. But you pointed me in the right direction and I found it in sys.sql_expression_dependencies.

    – Zikato
    1 hour ago







1




1





Did you look into sys.dm_sql_referenced_entities?

– Scott Hodgin
1 hour ago





Did you look into sys.dm_sql_referenced_entities?

– Scott Hodgin
1 hour ago













Yes, that's not it. But you pointed me in the right direction and I found it in sys.sql_expression_dependencies.

– Zikato
1 hour ago





Yes, that's not it. But you pointed me in the right direction and I found it in sys.sql_expression_dependencies.

– Zikato
1 hour ago










2 Answers
2






active

oldest

votes


















2














Thanks to Scott Hodgin I found it in sys.sql_expression_dependencies



SELECT 
OBJECT_NAME(sed.referencing_id) AS referencingTable
, pc.[name] AS computedColumn
, pc.is_computed
, cc.[name] AS referencedcolumn
, cc.is_computed
FROM sys.sql_expression_dependencies sed
JOIN sys.[columns] pc ON sed.referencing_minor_id = pc.column_id AND sed.referencing_id = pc.[object_id]
JOIN sys.[columns] cc ON sed.referenced_minor_id = cc.column_id AND sed.referenced_id = cc.[object_id]
WHERE sed.referencing_minor_id > 0 -- referencing object is Column
AND sed.referenced_minor_id > 0 -- referenced object is Column
AND sed.referencing_id = sed.referenced_id -- references the same table





share|improve this answer






























    1















    There is also sys.computed_columns which shows definition, but doesn't
    list columns in searchable manner.




    If I understand correctly you want to find which columns are referenced by the computed column.



    One solution would be searching the definition in sys.computed_columns with CHARINDEX() for each column where the object_id matches



    SELECT DISTINCT c.name, 
    cc.definition
    FROM sys.columns c
    CROSS APPLY
    (
    SELECT definition from sys.computed_columns cc
    WHERE c.object_id = cc.object_id
    AND CHARINDEX(c.name,cc.definition) > 0
    ) as cc;



    Quick test



    --Create a heap table.
    CREATE TABLE dbo.test(id int,
    val int);
    -- add computed column on two columns.
    ALTER TABLE dbo.test
    ADD computedcolumn as id + val;

    -- add a column that is not part of any computed column.
    ALTER TABLE dbo.test
    ADD bla int;


    The query for one specific table



    SELECT DISTINCT c.name, 
    cc.definition
    FROM sys.columns c
    CROSS APPLY
    (
    SELECT definition from sys.computed_columns cc
    WHERE c.object_id = cc.object_id
    AND CHARINDEX(c.name,cc.definition) > 0
    ) as cc
    where c.object_id = object_id('dbo.test');


    Result



    name definition
    id ([id]+[val])
    val ([id]+[val])





    share|improve this answer




















    • 2





      Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

      – Zikato
      2 hours ago











    • @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

      – Randi Vertongen
      2 hours ago











    Your Answer








    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "182"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f236660%2fhow-to-find-if-a-column-is-referenced-in-a-computed-column%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    2














    Thanks to Scott Hodgin I found it in sys.sql_expression_dependencies



    SELECT 
    OBJECT_NAME(sed.referencing_id) AS referencingTable
    , pc.[name] AS computedColumn
    , pc.is_computed
    , cc.[name] AS referencedcolumn
    , cc.is_computed
    FROM sys.sql_expression_dependencies sed
    JOIN sys.[columns] pc ON sed.referencing_minor_id = pc.column_id AND sed.referencing_id = pc.[object_id]
    JOIN sys.[columns] cc ON sed.referenced_minor_id = cc.column_id AND sed.referenced_id = cc.[object_id]
    WHERE sed.referencing_minor_id > 0 -- referencing object is Column
    AND sed.referenced_minor_id > 0 -- referenced object is Column
    AND sed.referencing_id = sed.referenced_id -- references the same table





    share|improve this answer



























      2














      Thanks to Scott Hodgin I found it in sys.sql_expression_dependencies



      SELECT 
      OBJECT_NAME(sed.referencing_id) AS referencingTable
      , pc.[name] AS computedColumn
      , pc.is_computed
      , cc.[name] AS referencedcolumn
      , cc.is_computed
      FROM sys.sql_expression_dependencies sed
      JOIN sys.[columns] pc ON sed.referencing_minor_id = pc.column_id AND sed.referencing_id = pc.[object_id]
      JOIN sys.[columns] cc ON sed.referenced_minor_id = cc.column_id AND sed.referenced_id = cc.[object_id]
      WHERE sed.referencing_minor_id > 0 -- referencing object is Column
      AND sed.referenced_minor_id > 0 -- referenced object is Column
      AND sed.referencing_id = sed.referenced_id -- references the same table





      share|improve this answer

























        2












        2








        2







        Thanks to Scott Hodgin I found it in sys.sql_expression_dependencies



        SELECT 
        OBJECT_NAME(sed.referencing_id) AS referencingTable
        , pc.[name] AS computedColumn
        , pc.is_computed
        , cc.[name] AS referencedcolumn
        , cc.is_computed
        FROM sys.sql_expression_dependencies sed
        JOIN sys.[columns] pc ON sed.referencing_minor_id = pc.column_id AND sed.referencing_id = pc.[object_id]
        JOIN sys.[columns] cc ON sed.referenced_minor_id = cc.column_id AND sed.referenced_id = cc.[object_id]
        WHERE sed.referencing_minor_id > 0 -- referencing object is Column
        AND sed.referenced_minor_id > 0 -- referenced object is Column
        AND sed.referencing_id = sed.referenced_id -- references the same table





        share|improve this answer













        Thanks to Scott Hodgin I found it in sys.sql_expression_dependencies



        SELECT 
        OBJECT_NAME(sed.referencing_id) AS referencingTable
        , pc.[name] AS computedColumn
        , pc.is_computed
        , cc.[name] AS referencedcolumn
        , cc.is_computed
        FROM sys.sql_expression_dependencies sed
        JOIN sys.[columns] pc ON sed.referencing_minor_id = pc.column_id AND sed.referencing_id = pc.[object_id]
        JOIN sys.[columns] cc ON sed.referenced_minor_id = cc.column_id AND sed.referenced_id = cc.[object_id]
        WHERE sed.referencing_minor_id > 0 -- referencing object is Column
        AND sed.referenced_minor_id > 0 -- referenced object is Column
        AND sed.referencing_id = sed.referenced_id -- references the same table






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 1 hour ago









        ZikatoZikato

        23918




        23918























            1















            There is also sys.computed_columns which shows definition, but doesn't
            list columns in searchable manner.




            If I understand correctly you want to find which columns are referenced by the computed column.



            One solution would be searching the definition in sys.computed_columns with CHARINDEX() for each column where the object_id matches



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc;



            Quick test



            --Create a heap table.
            CREATE TABLE dbo.test(id int,
            val int);
            -- add computed column on two columns.
            ALTER TABLE dbo.test
            ADD computedcolumn as id + val;

            -- add a column that is not part of any computed column.
            ALTER TABLE dbo.test
            ADD bla int;


            The query for one specific table



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc
            where c.object_id = object_id('dbo.test');


            Result



            name definition
            id ([id]+[val])
            val ([id]+[val])





            share|improve this answer




















            • 2





              Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

              – Zikato
              2 hours ago











            • @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

              – Randi Vertongen
              2 hours ago















            1















            There is also sys.computed_columns which shows definition, but doesn't
            list columns in searchable manner.




            If I understand correctly you want to find which columns are referenced by the computed column.



            One solution would be searching the definition in sys.computed_columns with CHARINDEX() for each column where the object_id matches



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc;



            Quick test



            --Create a heap table.
            CREATE TABLE dbo.test(id int,
            val int);
            -- add computed column on two columns.
            ALTER TABLE dbo.test
            ADD computedcolumn as id + val;

            -- add a column that is not part of any computed column.
            ALTER TABLE dbo.test
            ADD bla int;


            The query for one specific table



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc
            where c.object_id = object_id('dbo.test');


            Result



            name definition
            id ([id]+[val])
            val ([id]+[val])





            share|improve this answer




















            • 2





              Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

              – Zikato
              2 hours ago











            • @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

              – Randi Vertongen
              2 hours ago













            1












            1








            1








            There is also sys.computed_columns which shows definition, but doesn't
            list columns in searchable manner.




            If I understand correctly you want to find which columns are referenced by the computed column.



            One solution would be searching the definition in sys.computed_columns with CHARINDEX() for each column where the object_id matches



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc;



            Quick test



            --Create a heap table.
            CREATE TABLE dbo.test(id int,
            val int);
            -- add computed column on two columns.
            ALTER TABLE dbo.test
            ADD computedcolumn as id + val;

            -- add a column that is not part of any computed column.
            ALTER TABLE dbo.test
            ADD bla int;


            The query for one specific table



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc
            where c.object_id = object_id('dbo.test');


            Result



            name definition
            id ([id]+[val])
            val ([id]+[val])





            share|improve this answer
















            There is also sys.computed_columns which shows definition, but doesn't
            list columns in searchable manner.




            If I understand correctly you want to find which columns are referenced by the computed column.



            One solution would be searching the definition in sys.computed_columns with CHARINDEX() for each column where the object_id matches



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc;



            Quick test



            --Create a heap table.
            CREATE TABLE dbo.test(id int,
            val int);
            -- add computed column on two columns.
            ALTER TABLE dbo.test
            ADD computedcolumn as id + val;

            -- add a column that is not part of any computed column.
            ALTER TABLE dbo.test
            ADD bla int;


            The query for one specific table



            SELECT DISTINCT c.name, 
            cc.definition
            FROM sys.columns c
            CROSS APPLY
            (
            SELECT definition from sys.computed_columns cc
            WHERE c.object_id = cc.object_id
            AND CHARINDEX(c.name,cc.definition) > 0
            ) as cc
            where c.object_id = object_id('dbo.test');


            Result



            name definition
            id ([id]+[val])
            val ([id]+[val])






            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited 3 hours ago

























            answered 3 hours ago









            Randi VertongenRandi Vertongen

            5,2911926




            5,2911926







            • 2





              Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

              – Zikato
              2 hours ago











            • @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

              – Randi Vertongen
              2 hours ago












            • 2





              Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

              – Zikato
              2 hours ago











            • @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

              – Randi Vertongen
              2 hours ago







            2




            2





            Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

            – Zikato
            2 hours ago





            Good answer. Parsing occured to me and this is a good way to go about it. I was looking for a system catalogue, but I see I didn't specify it in the question. If there isn't a better answer, I'll accept it.

            – Zikato
            2 hours ago













            @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

            – Randi Vertongen
            2 hours ago





            @Zikato Thanks! I agree that there should be a better way to get it than parsing, maybe someone else knows a way to get it through a dmv.

            – Randi Vertongen
            2 hours ago

















            draft saved

            draft discarded
















































            Thanks for contributing an answer to Database Administrators Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f236660%2fhow-to-find-if-a-column-is-referenced-in-a-computed-column%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            hrsg3VrEw56bYOz6h7Ee6fso30vJsoExMEc 13sGhhLwgwk,lOig,jeQJJo TaL9PbPomPMnOG,MXUDGbuCfez88uo24
            02,LQLEs DzYUmpG9bq2aqRwbF

            Popular posts from this blog

            What is the result of assigning to std::vector::begin()? The Next CEO of Stack OverflowWhat are the differences between a pointer variable and a reference variable in C++?What does the explicit keyword mean?Concatenating two std::vectorsHow to find out if an item is present in a std::vector?Why is “using namespace std” considered bad practice?What is the “-->” operator in C++?What is the easiest way to initialize a std::vector with hardcoded elements?What is The Rule of Three?What are the basic rules and idioms for operator overloading?Why are std::begin and std::end “not memory safe”?

            Creating centerline of river in QGIS? The 2019 Stack Overflow Developer Survey Results Are In Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Finding centrelines from polygons in QGIS?Splitting line into two lines with GRASS GIS?Centroid of the equator and a pointpostgis: problems creating flow direction polyline; not all needed connections are drawnhow to make decent sense from scattered river depth measurementsQGIS Interpolation on Curved Grid (River DEMs)How to create automatic parking baysShortest path creation between two linesclipping layer using query builder in QGISFinding which side of closest polyline point lies on in QGIS?Create centerline from multi-digitized roadway lines Qgis 2.18Getting bathymetric contours confined only within river banks using QGIS?

            SQL Server 2016 - excessive memory grant warning on poor performing query The Next CEO of Stack OverflowFix for slow SQL_INLINE_TABLE_VALUED_FUNCTIONLarge memory grant requestsPoor performing Query -Tsql execution plan - estimated number of rows =1 Paste the PlanMSSQL - Query had to wait for memory grantRow estimates always too lowBad performance using “NOT IN”Warning about memory “Excessive Grant” in the query plan - how to find out what is causing it?Optimizing table valued function SQL ServerWhen does SQL Server warn about an Excessive Memory Grant?Warning in Execution Plan