SQL Code QA

  • In my experience, putting the 'ON' clause on a new line is more of an 'old school' habit going back to the days when you could only fit 80 characters on each line :hehe:

    In the old school habits for the database world, there would be no ON clause used at all. It was a matter of trying to figure out the joins vs conditions in the huge mess of a where clause.

    Sue

  • Sue_H (9/14/2016)

    In the old school habits for the database world, there would be no ON clause used at all. It was a matter of trying to figure out the joins vs conditions in the huge mess of a where clause.

    Sue

    Very true: there was some terrible code floating around in those days.

    To make things as readable as possible, I used to insist that the tables in the FROM clause appeared in 'join' order; the WHERE clause joined the tables in the same order; that each join condition was on a separate line and that each was aligned with the ones above it.

  • Luis Cazares (9/7/2016)


    colin.dunn (9/7/2016)


    Put the join ON clauses on the same line since they were so short.

    I usually have my ON clauses on the same line as my JOIN, but when he was testing it, he changed it to the next line.

    <rant>

    I don't like when people put the ON clauses in separate lines. It feels as if they weren't part of the JOIN. It seems like they still want to write code with the SQL-86 standard, where the tables and join conditions were set apart.

    </rant>

    That's one of the reasons for your DBA to tell you what means clunky to him/her. However, don't hesitate to come back for guidance. 😉

    And I feel just the opposite, Luis. I can't read a JOIN line when the ON clause is on the same physical line. I do, however, tend to indent the ON with a space or two to make it clear to me.

    Brandie Tarvin, MCITP Database AdministratorLiveJournal Blog: http://brandietarvin.livejournal.com/[/url]On LinkedIn!, Google+, and Twitter.Freelance Writer: ShadowrunLatchkeys: Nevermore, Latchkeys: The Bootleg War, and Latchkeys: Roscoes in the Night are now available on Nook and Kindle.

  • The Dixie Flatline (9/7/2016)


    Did he say it looks clunky or it runs clunky?

    I think your DBA is being really picky unless you have company standards for formatting, but.

    SELECT d.WORK_TYPE AS [Work Type],

    CONVERT(varchar, a.ACT_DATE, 103) AS [Date Opened],

    CONVERT(varchar, a.ACT_DATE, 108) AS [Time Opened],

    b.IT_IDEN AS [Item ID],

    CONVERT(varchar, @checkDate, 103) AS [Run Date],

    a.CUSTID AS [Customer Number],

    CONVERT(varchar, ACT_CLOSE, 103) AS [Close Date],

    DATEDIFF(day, a.ACT_DATE, CAST(checkDate AS DATE)) AS [Days Elapsed],

    a.PERSON AS [Started By],

    c.HANDOFF AS [Assigned To],

    a.TYPE_STAT AS [Status Code]

    FROM main.SOURCE_DATA a

    JOIN main.LINKED_DATA bON a.ID=b.ID

    JOIN main.LOOK_UP cON a.ID=c.ID

    JOIN main.LOOK_UP_TYPE d ON a.ID_TYPE=d.ID_TYPE

    WHERE a.ACT_DATE >= CONVERT(DATE,DATEADD(day, DATEDIFF(day, 1, GETDATE()), 0))

    OR a.ACT_CLOSE IS NULL

    ORDER BY [Days Elapsed] DESC, [Work Type]

    Got rid of your variable declaration and just pit the conversion code in the WHERE clause

    So I read through the entire post to verify no one had responded to this one...

    I have to disagree with the notion of replacing the variable declaration. Depending on the situation, it is possibly easier to process all those date functions and converts only once for the variable and not have to process it each time the query grabs a row.

    Yes I know this is set-based code, but the WHERE clause does sometimes (again, depending on the situation and how the DB is set up) process those functions multiple times. Though I don't have an example off the top of my head to prove the point...

    Brandie Tarvin, MCITP Database AdministratorLiveJournal Blog: http://brandietarvin.livejournal.com/[/url]On LinkedIn!, Google+, and Twitter.Freelance Writer: ShadowrunLatchkeys: Nevermore, Latchkeys: The Bootleg War, and Latchkeys: Roscoes in the Night are now available on Nook and Kindle.

  • Fast.Eddie (9/7/2016)


    Good Afternoon All, This is my first post.

    I created the below code and if works fine. However my DBA said "It does the job but is clunky" how could this be re-written so it's not "clunky"?

    USE TESTDB

    GO

    DECLARE @checkDate DATE

    SET @checkDate = DATEADD(day, DATEDIFF(day, 1, GETDATE()), 0)

    SELECT d.WORK_TYPE AS 'Work Type',

    CONVERT(varchar, a.ACT_DATE, 103) AS 'Date Opened',

    CONVERT(varchar, a.ACT_DATE, 108) AS 'Time Opened',

    b.IT_IDEN AS 'Item ID',

    CONVERT(varchar, @checkDate, 103) AS 'Run Date',

    a.CUSTID AS 'Customer Number',

    CONVERT(varchar, ACT_CLOSE, 103) AS 'Close Date',

    DATEDIFF(day, a.ACT_DATE, CAST(checkDate AS DATE)) AS 'Days Elapsed',

    a.PERSON AS 'Started By',

    c.HANDOFF AS 'Assigned To',

    a.TYPE_STAT AS 'Status Code'

    FROM main.SOURCE_DATA a

    JOIN main.LINKED_DATA b

    ON a.ID=b.ID

    JOIN main.LOOK_UP c

    ON a.ID=c.ID

    JOIN main.LOOK_UP_TYPE d

    ON a.ID_TYPE=d.ID_TYPE

    WHERE CAST(a.ACT_DATE AS DATE) >= @checkDate OR a.ACT_CLOSE IS NULL

    ORDER BY 8 DESC,1

    As a last comment on your code, some companies / DBAs prefer it when JOINs are better defined. I.E., instead of JOIN, use INNER JOIN and then either LEFT OUTER JOIN or LEFT JOIN and either RIGHT OUTER JOIN or RIGHT JOIN, just so everyone coming to examine the code after you knows you deliberately were doing an INNER JOIN as opposed to an OUTER JOIN where you may have forgotten to put in the direction of the JOIN.

    This is more of a semantics, but it's something that we preach in our office. As well as making our devs use "AS <alias>" in the SELECT list for the column aliases so we know they didn't accidentally forget a comma in the SELECT list and force one column to take the name of a following column as an alias. (This happens more then you might think).

    We don't use AS in the table aliases, though, because that's usually pretty clear.

    Brandie Tarvin, MCITP Database AdministratorLiveJournal Blog: http://brandietarvin.livejournal.com/[/url]On LinkedIn!, Google+, and Twitter.Freelance Writer: ShadowrunLatchkeys: Nevermore, Latchkeys: The Bootleg War, and Latchkeys: Roscoes in the Night are now available on Nook and Kindle.

  • Brandie Tarvin (9/15/2016)


    Fast.Eddie (9/7/2016)


    Good Afternoon All, This is my first post.

    I created the below code and if works fine. However my DBA said "It does the job but is clunky" how could this be re-written so it's not "clunky"?

    USE TESTDB

    GO

    DECLARE @checkDate DATE

    SET @checkDate = DATEADD(day, DATEDIFF(day, 1, GETDATE()), 0)

    SELECT d.WORK_TYPE AS 'Work Type',

    CONVERT(varchar, a.ACT_DATE, 103) AS 'Date Opened',

    CONVERT(varchar, a.ACT_DATE, 108) AS 'Time Opened',

    b.IT_IDEN AS 'Item ID',

    CONVERT(varchar, @checkDate, 103) AS 'Run Date',

    a.CUSTID AS 'Customer Number',

    CONVERT(varchar, ACT_CLOSE, 103) AS 'Close Date',

    DATEDIFF(day, a.ACT_DATE, CAST(checkDate AS DATE)) AS 'Days Elapsed',

    a.PERSON AS 'Started By',

    c.HANDOFF AS 'Assigned To',

    a.TYPE_STAT AS 'Status Code'

    FROM main.SOURCE_DATA a

    JOIN main.LINKED_DATA b

    ON a.ID=b.ID

    JOIN main.LOOK_UP c

    ON a.ID=c.ID

    JOIN main.LOOK_UP_TYPE d

    ON a.ID_TYPE=d.ID_TYPE

    WHERE CAST(a.ACT_DATE AS DATE) >= @checkDate OR a.ACT_CLOSE IS NULL

    ORDER BY 8 DESC,1

    As a last comment on your code, some companies / DBAs prefer it when JOINs are better defined. I.E., instead of JOIN, use INNER JOIN and then either LEFT OUTER JOIN or LEFT JOIN and either RIGHT OUTER JOIN or RIGHT JOIN, just so everyone coming to examine the code after you knows you deliberately were doing an INNER JOIN as opposed to an OUTER JOIN where you may have forgotten to put in the direction of the JOIN.

    This is more of a semantics, but it's something that we preach in our office. As well as making our devs use "AS <alias>" in the SELECT list for the column aliases so we know they didn't accidentally forget a comma in the SELECT list and force one column to take the name of a following column as an alias. (This happens more then you might think).

    We don't use AS in the table aliases, though, because that's usually pretty clear.

    My opinion is that if you have SQL devs who confuse JOIN, LEFT JOIN and RIGHT JOIN, they are not fit for the job and should be further trained or reassigned.

    Using AS in column aliases is just a ton of extra white noise which (again, my opinion) causes clutter and makes code harder to read.

    And rather than this format:

    Select

    Col1 SomeCol,

    Column2 SomeOtherCol,

    ThisOtherCol SomeCol3,

    I find this much easier to scan

    Select

    SomeCol = Col1,

    SomeOtherCol = Column2,

    SomeCol3 = ThisOtherCol

    But every developer has their own take on this ...

    The absence of evidence is not evidence of absence
    - Martin Rees
    The absence of consumable DDL, sample data and desired results is, however, evidence of the absence of my response
    - Phil Parkin

  • Please note I'm looking at the layout, not the detail. Here's a suggestion:

    USE TESTDB

    GO

    DECLARE @checkDate DATE = DATEADD(day, DATEDIFF(day, 1, GETDATE()), 0);

    SELECT[Work Type]= d.WORK_TYPE,

    [Date Opened]= CONVERT(varchar, a.ACT_DATE, 103),

    [Time Opened]= CONVERT(varchar, a.ACT_DATE, 108),

    [Item ID]= b.IT_IDEN,

    [Run Date]= CONVERT(varchar, @checkDate, 103),

    [Customer Number]= a.CUSTID,

    [Close Date]= CONVERT(varchar, ACT_CLOSE, 103),

    [Days Elapsed]= DATEDIFF(day, a.ACT_DATE, CAST(checkDate AS DATE)),

    [Started By]= a.PERSON,

    [Assigned To]= c.HANDOFF,

    [Status Code]= a.TYPE_STAT

    FROM main.SOURCE_DATAa

    JOIN main.LINKED_DATAb ON a.ID= b.ID

    JOIN main.LOOK_UPc ON a.ID= c.ID

    JOIN main.LOOK_UP_TYPEd ON a.ID_TYPE= d.ID_TYPE

    WHERE CAST(a.ACT_DATE AS DATE) >= @checkDate

    OR a.ACT_CLOSE IS NULL

    ORDER BY 8 DESC,1;

    You'll see you don't have to parse the code to get a list of field names (I put them first because the definitions tend to be longer and more variable) or the table aliases - they're all underneath each other, as are the aliases they reference.

    I know it's not perfect, and we'll never get total agreement, but particularly when taking on someone else's code, I find the above makes things (particularly bugs) a lot clearer.

  • We don't use AS in the table aliases, though, because that's usually pretty clear.

    I find it clearer if AS is used consistently when aliasing anywhere. If I can apply your reasoning here on spelling out joins, a "b" could be a errant left over character that was not meant to be there. AS, including the color coding, is easier on the eyes.

    A pet peeve of mine is when the columns used in the select clause as the result of joins are not prefixed. You may know that someColumn came from TableC and only exists in that table. But I don't. I like to see this entered as c.someColumn consistently for all columns.

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

  • MMartin1 (9/15/2016)


    We don't use AS in the table aliases, though, because that's usually pretty clear.

    I find it clearer if AS is used consistently when aliasing anywhere. If I can apply your reasoning here on spelling out joins, a "b" could be a errant left over character that was not meant to be there. AS, including the color coding, is easier on the eyes.

    A pet peeve of mine is when the columns used in the select clause as the result of joins are not prefixed. You may know that someColumn came from TableC and only exists in that table. But I don't. I like to see this entered as c.someColumn consistently for all columns.

    I didn't used to use 'AS', but I've since been persuaded by the same reasoning.

    I also agree that every column reference should be prefixed by the alias, except perhaps where there is only one table. But SQL Prompt puts those in for me anyway, so it doesn't happen 😛

  • I don't think I've ever done a RIGHT JOIN in production. :ermm:

    __________________________________________________

    Against stupidity the gods themselves contend in vain. -- Friedrich Schiller
    Stop, children, what's that sound? Everybody look what's going down. -- Stephen Stills

  • MMartin1 (9/15/2016)


    A pet peeve of mine is when the columns used in the select clause as the result of joins are not prefixed. You may know that someColumn came from TableC and only exists in that table. But I don't. I like to see this entered as c.someColumn consistently for all columns.

    Preach it!

    +1

    Brandie Tarvin, MCITP Database AdministratorLiveJournal Blog: http://brandietarvin.livejournal.com/[/url]On LinkedIn!, Google+, and Twitter.Freelance Writer: ShadowrunLatchkeys: Nevermore, Latchkeys: The Bootleg War, and Latchkeys: Roscoes in the Night are now available on Nook and Kindle.

  • MMartin1 (9/15/2016)


    We don't use AS in the table aliases, though, because that's usually pretty clear.

    I find it clearer if AS is used consistently when aliasing anywhere. If I can apply your reasoning here on spelling out joins, a "b" could be a errant left over character that was not meant to be there. AS, including the color coding, is easier on the eyes.

    A pet peeve of mine is when the columns used in the select clause as the result of joins are not prefixed. You may know that someColumn came from TableC and only exists in that table. But I don't. I like to see this entered as c.someColumn consistently for all columns.

    Easier on your eyes. For me, 'as' in aliases is just extra noise that my brain needs to filter out.

    I agree about object qualification, however. SQL Prompt takes care of that, in cases where it is missing.

    The absence of evidence is not evidence of absence
    - Martin Rees
    The absence of consumable DDL, sample data and desired results is, however, evidence of the absence of my response
    - Phil Parkin

  • The Dixie Flatline (9/15/2016)


    I don't think I've ever done a RIGHT JOIN in production. :ermm:

    I have a power user who does it all the time because he doesn't seem to get it's easier in a "reading left to right" culture to just put tables in that order.

    Brandie Tarvin, MCITP Database AdministratorLiveJournal Blog: http://brandietarvin.livejournal.com/[/url]On LinkedIn!, Google+, and Twitter.Freelance Writer: ShadowrunLatchkeys: Nevermore, Latchkeys: The Bootleg War, and Latchkeys: Roscoes in the Night are now available on Nook and Kindle.

  • The Dixie Flatline (9/15/2016)


    I don't think I've ever done a RIGHT JOIN in production. :ermm:

    Ditto... Keep the "left table" to the left...

  • Phil Parkin (9/15/2016)


    Brandie Tarvin (9/15/2016)


    Fast.Eddie (9/7/2016)


    Good Afternoon All, This is my first post.

    I created the below code and if works fine. However my DBA said "It does the job but is clunky" how could this be re-written so it's not "clunky"?

    USE TESTDB

    GO

    DECLARE @checkDate DATE

    SET @checkDate = DATEADD(day, DATEDIFF(day, 1, GETDATE()), 0)

    SELECT d.WORK_TYPE AS 'Work Type',

    CONVERT(varchar, a.ACT_DATE, 103) AS 'Date Opened',

    CONVERT(varchar, a.ACT_DATE, 108) AS 'Time Opened',

    b.IT_IDEN AS 'Item ID',

    CONVERT(varchar, @checkDate, 103) AS 'Run Date',

    a.CUSTID AS 'Customer Number',

    CONVERT(varchar, ACT_CLOSE, 103) AS 'Close Date',

    DATEDIFF(day, a.ACT_DATE, CAST(checkDate AS DATE)) AS 'Days Elapsed',

    a.PERSON AS 'Started By',

    c.HANDOFF AS 'Assigned To',

    a.TYPE_STAT AS 'Status Code'

    FROM main.SOURCE_DATA a

    JOIN main.LINKED_DATA b

    ON a.ID=b.ID

    JOIN main.LOOK_UP c

    ON a.ID=c.ID

    JOIN main.LOOK_UP_TYPE d

    ON a.ID_TYPE=d.ID_TYPE

    WHERE CAST(a.ACT_DATE AS DATE) >= @checkDate OR a.ACT_CLOSE IS NULL

    ORDER BY 8 DESC,1

    As a last comment on your code, some companies / DBAs prefer it when JOINs are better defined. I.E., instead of JOIN, use INNER JOIN and then either LEFT OUTER JOIN or LEFT JOIN and either RIGHT OUTER JOIN or RIGHT JOIN, just so everyone coming to examine the code after you knows you deliberately were doing an INNER JOIN as opposed to an OUTER JOIN where you may have forgotten to put in the direction of the JOIN.

    This is more of a semantics, but it's something that we preach in our office. As well as making our devs use "AS <alias>" in the SELECT list for the column aliases so we know they didn't accidentally forget a comma in the SELECT list and force one column to take the name of a following column as an alias. (This happens more then you might think).

    We don't use AS in the table aliases, though, because that's usually pretty clear.

    My opinion is that if you have SQL devs who confuse JOIN, LEFT JOIN and RIGHT JOIN, they are not fit for the job and should be further trained or reassigned.

    Using AS in column aliases is just a ton of extra white noise which (again, my opinion) causes clutter and makes code harder to read.

    And rather than this format:

    Select

    Col1 SomeCol,

    Column2 SomeOtherCol,

    ThisOtherCol SomeCol3,

    I find this much easier to scan

    Select

    SomeCol = Col1,

    SomeOtherCol = Column2,

    SomeCol3 = ThisOtherCol

    But every developer has their own take on this ...

    As a DBA, I strongly prefer that you always code "INNER JOIN" and not just JOIN. Otherwise, if I need to test adding a join hint, I have to add the "INNER" myself. "INNER" is required when adding a hint for the join type.

    SQL DBA,SQL Server MVP(07, 08, 09) "It's a dog-eat-dog world, and I'm wearing Milk-Bone underwear." "Norm", on "Cheers". Also from "Cheers", from "Carla": "You need to know 3 things about Tortelli men: Tortelli men draw women like flies; Tortelli men treat women like flies; Tortelli men's brains are in their flies".

Viewing 15 posts - 31 through 44 (of 44 total)

You must be logged in to reply to this topic. Login to reply