Easy PL/SQL Question

Hello, I am new to PL/SQL. Trying to run this query against Oracle 8i:
SELECT DISTINCT DIALED_NUMBER
FROM STATDBA.FREE_CALL tb1
WHERE DIALED_NUMBER NOT IN
                    (SELECT DISTINCT DIALED_NUMBER
                    FROM     STATDBA.FREE_CALL AS tb2
                    WHERE     tb2.CALL_DATE >= TO_DATE('20050901', 'YYYYMMDD')
The error I get is ORA-00907 "missing right parenthesis".
The idea here is to get all the numbers from the talbe, which don't have any activity since 09-01-2005. What am I doing wrong?

(still don't know why, but certainly fixed the problem) Because the FROM syntax does not support the use of AS when we alias table names. So Oracle treated[i] AS as the table alias and then expected a comma or something before tb2. In this respect table aliases are different to column aliases where AS is supported (but optional).
Cheers, APC

Similar Messages

  • Easy-ish sql question

    sorry guys, wasnt sure where else to put this so hope it is ok to post it here. I currently have a field in my database which stores date and time however i am writting an sql statemenet and need to only use the date of the datetime, what would be the correct syntext to do sowould i have to use to_char etc?
    Thank you.

    Are you doing something specific to Oracle Forms? If not, you may want to consider posting your question in the SQL - PL/SQL forum (url below). If this is Forms specific, please indicate exactly which Forms version you are using. The database version you plan to use may also be helpful as there may be a variety of ways of accomplishing your goal depending on the versions.
    PL/SQL

  • SQL Question Bank and Answers for Practise

    Dear Readers:
    Does any one have any recommendation on SQL question bank and answers where I could practice my SQL.
    I have developed some basic knowledge of SQL thanks to the MS community, but I am looking for some additional Questions or textbook  recommendations which has questions and answers to queries for practice.
    Best Wishes,
    SQL75

    Hi,
    Refer below post.
    https://social.msdn.microsoft.com/Forums/sqlserver/en-US/446b2247-5124-49c1-90c9-b7fea0aa4f83/sql-dba-books?forum=sqlgetstarted
    Please mark solved if I've answered your question, vote for it as helpful to help other users find a solution quicker
    Praveen Dsa | MCITP - Database Administrator 2008 |
    My Blog | My Page

  • Sql question : TRUNCATE vs Delete

    hi
    this is sql question, i don't know where i should post it, so here it is.
    i just want to know the best usage of each. both commands delete records in a table, one deletes all, and the other can do the same plus option to delete specified records. if i just want to purge the table. which one is better and why? thanks

    this is crucial to my design, i need to be able to
    rollback if one of the process in the transaction
    failed, the whole transaction should rollback. if
    truncate does not give me this capability, then i have
    to consider Delete.From the Oracle manual (sans the pretty formatting):
    TRUNCATE
    Caution: You cannot roll back a TRUNCATE statement.
    Purpose
    Use the TRUNCATE statement to remove all rows from a table or cluster. By default,
    Oracle also deallocates all space used by the removed rows except that specified by
    the MINEXTENTS storage parameter and sets the NEXT storage parameter to the size
    of the last extent removed from the segment by the truncation process.
    Removing rows with the TRUNCATE statement can be more efficient than dropping
    and re-creating a table. Dropping and re-creating a table invalidates the table?s
    dependent objects, requires you to regrant object privileges on the table, and
    requires you to re-create the table?s indexes, integrity constraints, and triggers and
    respecify its storage parameters. Truncating has none of these effects.
    See Also:
    DELETE on page 16-55 and DROP TABLE on page 17-6 for
    information on other ways to drop table data from the database
    DROP CLUSTER on page 16-67 for information on dropping
    cluster tables
    Prerequisites
    To truncate a table or cluster, the table or cluster must be in your schema or you
    must have DROP ANY TABLE system privilege.

  • Urgent SQL question : how to flip vertical row values to horizontal ?

    Hello, Oracle people !
    I have an urgent SQL question : (simple for you)
    using SELECT statement, how to convert vertical row values to horizontal ?
    For example :
    (Given result-set)
    MANAGER COLUMN1 COLUMN2 COLUMN3
    K. Smith ......1
    K. Smith ...............1
    K. Smith ........................1
    (Needed result-set)
    MANAGER COLUMN1 COLUMN2 COLUMN3
    K. Smith ......1 .......1 .......1
    I know you can, just don't remeber how and can't find exactly answer I'm looking for. Probably using some analytic SQL function (CAST OVER, PARTITION BY, etc.)
    Please Help !!!
    Thanx !
    Steve.

    scott@ORA92> column vice_president format a30
    scott@ORA92> SELECT f.VICE_PRESIDENT, A.DAYS_5, B.DAYS_10, C.DAYS_20, D.DAYS_30, E.DAYS_40
      2  FROM   (select t2.*,
      3                row_number () over
      4                  (partition by vice_president
      5                   order by days_5, days_10, days_20, days_30, days_40) rn
      6            from   t2) f,
      7           (SELECT T2.*,
      8                row_number () over (partition by vice_president order by days_5) RN
      9            FROM   T2 WHERE DAYS_5 IS NOT NULL) A,
    10           (SELECT T2.*,
    11                row_number () over (partition by vice_president order by days_10) RN
    12            FROM   T2 WHERE DAYS_10 IS NOT NULL) B,
    13           (SELECT T2.*,
    14                row_number () over (partition by vice_president order by days_20) RN
    15            FROM   T2 WHERE DAYS_20 IS NOT NULL) C,
    16           (SELECT T2.*,
    17                row_number () over (partition by vice_president order by days_30) RN
    18            FROM   T2 WHERE DAYS_30 IS NOT NULL) D,
    19           (SELECT T2.*,
    20                row_number () over (partition by vice_president order by days_40) RN
    21            FROM   T2 WHERE DAYS_40 IS NOT NULL) E
    22  WHERE  f.VICE_PRESIDENT = A.VICE_PRESIDENT (+)
    23  AND    f.VICE_PRESIDENT = B.VICE_PRESIDENT (+)
    24  AND    f.VICE_PRESIDENT = C.VICE_PRESIDENT (+)
    25  AND    f.VICE_PRESIDENT = D.VICE_PRESIDENT (+)
    26  AND    f.VICE_PRESIDENT = E.VICE_PRESIDENT (+)
    27  AND    f.RN = A.RN (+)
    28  AND    f.RN = B.RN (+)
    29  AND    f.RN = C.RN (+)
    30  AND    f.RN = D.RN (+)
    31  AND    f.RN = E.RN (+)
    32  and    (a.days_5 is not null
    33            or b.days_10 is not null
    34            or c.days_20 is not null
    35            or d.days_30 is not null
    36            or e.days_40 is not null)
    37  /
    VICE_PRESIDENT                     DAYS_5    DAYS_10    DAYS_20    DAYS_30    DAYS_40
    Fedele Mark                                                          35473      35209
    Fedele Mark                                                          35479      35258
    Schultz Christine                              35700
    South John                                                                      35253
    Stack Kevin                                    35701      35604      35402      35115
    Stack Kevin                                    35705      35635      35415      35156
    Stack Kevin                                    35706      35642      35472      35295
    Stack Kevin                                    35707      35666      35477
    Stack Kevin                                               35667      35480
    Stack Kevin                                               35686
    Unknown                             35817      35698      35596      35363      35006
    Unknown                                        35702      35597      35365      35149
    Unknown                                        35724      35599      35370      35155
    Unknown                                                   35600      35413      35344
    Unknown                                                   35601      35451      35345
    Unknown                                                   35602      35467
    Unknown                                                   35603      35468
    Unknown                                                   35607      35475
    Unknown                                                   35643      35508
    Unknown                                                   35644
    Unknown                                                   35669
    Unknown                                                   35684
    Walmsley Brian                                 35725      35598
    23 rows selected.

  • SQL question (easy?  hard?  dunno!)

    Not sure if this is really easy and I'm being dense but....
    Given two tables, A & B, how (using SQL only) can I tell whether they contain identical data?
    Given that it's not possible to get boolean result from SQL, I don't mind (within reason!) what format the result takes
    Cheers
    RT

    Andrew's query does not work as expected **if there are duplicate rows in each table**. No offence to you Andrew, I am just pointing it out as the matter of the subject, read it to the end and you will see how I found out about this, I did not mean to fail your code in any way.SQL> select * from inv;
           SEQ INV                         AMT       AMT2
             1 AB12                       2000      702.4
             2 ABC123                     2000       48.6
             3 1234                        100         10
    -- duplicate all the rows in inv table
    SQL> insert into inv select * from inv;
    3 rows created.
    SQL> select * from inv;
           SEQ INV                         AMT       AMT2
             1 AB12                       2000      702.4
             2 ABC123                     2000       48.6
             3 1234                        100         10
             1 AB12                       2000      702.4
             2 ABC123                     2000       48.6
             3 1234                        100         10
    6 rows selected.
    SQL> select * from inv2;
    no rows selected
    -- Make both tables indentical
    SQL> insert into inv2 select * from inv;
    6 rows created.
    SQL> SELECT decode(count(*) , 1, 'SAME', 'DIFFERENT') whatever
      2  FROM   ( SELECT count(*) t FROM inv
      3           INTERSECT
      4           SELECT count(*) FROM inv2 ) tot_rec
      5         , (SELECT count(*) t FROM ( SELECT * FROM inv
      6                                     INTERSECT
      7                                     SELECT *  FROM inv2 ) ) tot_match
      8  WHERE tot_rec.t = tot_match.t
      9  /
    WHATEVER
    DIFFERENT
    -- In fact they are identical
    SQL> select * from inv
      2  minus
      3  select * from inv2;
    no rows selected
    SQL> select * from inv2
      2  minus
      3  select * from inv;
    no rows selectedFollowing version has the same problem. I am just posting it for the relevance.
    In case where where we can assume that there would not be any duplicate
    rows in each table, then here is another simple solution, SELECT decode(cnt1, cnt2, decode(cnt1, cnt3, 'TRUE', 'FALSE'), 'FALSE') yes_no
    FROM
    (select count(*) cnt1 from inv),
    (select count(*) cnt2 from inv2),
    (select count(*) cnt3 from (select * from inv union select * from inv2))I was thinking about duplicates problem with UNION alternative and that is when
    I found out that Andrew's SQL has the same caveat.
    Thx,
    SriDHAR

  • Please Help!!  Easy Application Tuning Question

    Ok - this should be an easy one for seasoned vets (but not for a newbie like me)
    I've been asked by the boss-man to "find and tune the SQL that's causing the slowdown . . . " I'm on Oracle 817 running Peoplesoft Application. I've located the main problems with the Application and have some solid ideas about how to improve the SQL. So - my question. How the heck do I get into the Peoplesoft (or any other Application for that matter) SQL code to change it. Everything I read says, " . . . and then you can go in and tune the SQL . . . " but never exaplins how exactly to 'get in'. I can't imaging there is a File-->Open-->SQL Code feature, it must be more complex than that. So what am I missing here and how do I get to the place where I can change the Application's SQL for tuning?!?!?!?
    Thanks in advance for any help you give.

    Peoplesoft owns the application code. So you can't change the application code. However, you can examine the code and see if there are some indices that you can create to improve the query. Also, you will need to rebuild your statistics. As a matter of maintenance, you should rebuild your indices and statistics on a regular schedule. Especially if your optimizer parameter is choose and you have high volatility.
    Alternatively, you could ask Peoplesoft to provide you with a patch.
    Maybe someone else has another idea?
    LM

  • Locator SQL Questions

    Gentlemen,
    I have a table in Locator that is made of of polygons (loaded via MapInfo EasyLoader). What I need to do is to send Oracle a latitude and longitude and have Oracle return the polygon in which that location falls in. I am new to loator and so this is probably an easy question. I have been experimenting with SQL statements and I tried the following:
    Select MUSYM From ENCLASS_USER.SOILMU_A_IA001
    Where SDO_INSIDE(sdo_geometry(2001, 8307, sdo_point_type(-94.53825,41.38343, NULL),null,null),GEOLOC) = 'TRUE'
    The error returned indicates the "interface not supportrd without a spatial index". The table has a spatial index, however I think that the problem is with the latitude and longitude portion of the SQL. In the above statement, MUSYM is the value of the column in the polygon table I need returned and GEOLOC is the SDO_GEOMETRY Column. The Lat/Long coordinates are -94.53825,41.38343 in the example above.
    How do I construct this SQL so that it will work?
    Thansk for your help,
    Tim Fast
    Pioneer Hi-Bred International, Inc.

    The SQL that I am using is:
    Select MUSYM From ENCLASS_USER.SOILMU_A_IA001
    Where SDO_INSIDE
    (GEOLOC,sdo_geometry(2001, 8307, sdo_point_type(-94.542208,41.383796, NULL),null,null)) = 'TRUE'
    It should return the MUSYM of "370B"
    I don't know how to send you the sample rows but here are three rows in which the first one is the polygon that should be returned. The columns are "|" delimited when exported form Oracle.
    AREASYMBOL|SPATIALVER|MUSYM|MUKEY|MI_STYLE|MI_PRINX|GEOLOC
    IA001|0|370B|402176||1|(2003, 8307, (-94.54199904, 41.38330203, ), (1, 1003, 1, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ), (-94.54315104, 41.38333398, -94.54303116, 41.38323597, -94.543029, 41.38314201, -94.54290912, 41.383044, -94.54279212, 41.38304598, -94.54267188, 41.38294797, -94.54232088, 41.38294896, -94.54184208, 41.38256304, -94.541724, 41.38256502, -94.54160484, 41.38246701, -94.54148784, 41.38246899, -94.54136796, 41.38237197, -94.54125096, 41.38237296, -94.54077612, 41.38198803, -94.54077504, 41.38188903, -94.54030596, 41.38150302, -94.54018896, 41.381505, -94.53960684, 41.38102098, -94.53948984, 41.38102296, -94.53902904, 41.38063704, -94.53856212, 41.38063902, -94.53844404, 41.38073496, -94.53844116, 41.380929, -94.53878784, 41.381217, -94.53890412, 41.38121601, -94.53902004, 41.38131303, -94.53913704, 41.381316, -94.53936996, 41.38150698, -94.53937104, 41.38179498, -94.53960396, 41.38179597, -94.53995784, 41.38208397, -94.53996108, 41.38227801, -94.54067892, 41.38285401, -94.54056516, 41.38295004, -94.54056804, 41.38304904, -94.54092804, 41.38333704, -94.54104504, 41.38333497, -94.54128588, 41.38353, -94.54140216, 41.38352901, -94.54164192, 41.383719, -94.54164912, 41.38391196, -94.54153608, 41.38400898, -94.54130316, 41.384007, -94.541076, 41.38420401, -94.54119588, 41.38429698, -94.54119912, 41.38439598, -94.541319, 41.38448904, -94.54132188, 41.38458804, -94.54144104, 41.38468101, -94.54144392, 41.38478001))
    IA001|0|370C2|402178||2|(2003, 8307, (-94.53918312, 41.38067601, ), (1, 1003, 1, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ), (-94.53523392, 41.378121, -94.535001, 41.37812397, -94.53488616, 41.37802704, -94.53465288, 41.37803001, -94.53453696, 41.377932, -94.53407112, 41.37793398, -94.53395304, 41.37803001, -94.53395304, 41.37812496, -94.53418416, 41.37831999, -94.53417984, 41.37861204, -94.53429504, 41.37870996, -94.53429396, 41.378805, -94.53440916, 41.37890202, -94.53440304, 41.37928902, -94.53428496, 41.37939, -94.53382092, 41.37939198, -94.53370716, 41.37929397, -94.53335904, 41.37929397, -94.53324204, 41.37939099, -94.53324096, 41.37948999, -94.53358404, 41.37977799, -94.53427884, 41.37977799, -94.53439584, 41.37968097, -94.53451212, 41.37967998, -94.53474792, 41.37948297, -94.53521196, 41.37948099, -94.53532608, 41.379579, -94.535208, 41.37967503, -94.53520404, 41.37987303, -94.53531888, 41.379966, -94.53543408, 41.37996897, -94.53566988, 41.37977304, -94.53601908, 41.37977196, -94.53613284, 41.37986997, -94.53625092, 41.37976899, -94.53636684, 41.37977196, -94.53659616, 41.37996303, -94.536594, 41.38006203, -94.53670812, 41.38016004, -94.53670092, 41.38054704, -94.53658284, 41.38064298, -94.53634992, 41.38064199, -94.53623292, 41.38074198, -94.53600108, 41.38074099, -94.535766, 41.38093296, -94.53588084, 41.38103097, -94.53669408, 41.38102899, -94.53692808, 41.38083702, -94.53727692, 41.38083603, -94.53739212, 41.380929))
    IA001|0|570C2|402192||3|(2003, 8307, (-94.54121496, 41.38369497, ), (1, 1003, 1, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ), (-94.53887784, 41.38449498, -94.53875688, 41.38439697, -94.53863988, 41.38439904, -94.53852108, 41.38430103, -94.53817188, 41.38430103, -94.53805992, 41.38439697, -94.53794292, 41.38439904, -94.53770208, 41.38420896, -94.53746988, 41.38420698, -94.53735, 41.38411401, -94.537233, 41.38411104, -94.53711312, 41.38401798, -94.53653208, 41.38401699, -94.53629088, 41.383827, -94.53582612, 41.38382799, -94.53571488, 41.38392402, -94.53571884, 41.38401897, -94.53584016, 41.38411599, -94.53584304, 41.38421103, -94.53620484, 41.38449903, -94.537134, 41.38449498, -94.53725388, 41.38459299, -94.53725892, 41.38468704, -94.53737916, 41.38478496, -94.53738312, 41.38487901, -94.537503, 41.38497702, -94.53819996, 41.38497702, -94.53831984, 41.385069, -94.53843612, 41.38506801, -94.53855492, 41.38516503, -94.53867084, 41.38516404, -94.53891096, 41.38535898, -94.53902688, 41.385357, -94.539384, 41.385645, -94.53949992, 41.38564401, -94.53961188, 41.38554798, -94.53972816, 41.385546, -94.53995388, 41.38535403, -94.54007016, 41.385357, -94.54018284, 41.38526097, -94.54099392, 41.38525899, -94.54111308, 41.38535196, -94.54122612, 41.38525602, -94.54134204, 41.38525899, -94.54156884, 41.38506603, -94.54156308, 41.38487298, -94.54144392, 41.38478001, -94.54144104, 41.38468101, -94.54132188, 41.38458804, -94.541319, 41.38448904))
    Tim Fast

  • Beggining SQL Question Package Question

    After creating this bit of code for c_Pi
    SQL> create or replace package MATH_CONSTANTS is
    c_Pi constant number := 3.14159265; end MATH_CONSTANTS;
    Create an unnamed block of code which prompts the user for a single numeric parameter, v_radius. This module should calculate the area of a circle using a radius equal to the inputted value along with c_Pi from the MATH_CONSTANTS package and subsequently display this information in a meaningful manner to the user.
    Essentially how would I be able to take the user input and put it in a manner meaningful to the user (i.e. show it in a DBMS_OUTPUT.PUT_LINE(V_radius))
    Also
    For this following code, will it work and if not how should it be changed around?
    Create or Replace Package OCTOBER12LAB As
    procedure CONVERT(convID IN NUMBER, Measure IN NUMBER); end OCTOBER12LAB;
    Create or Replace Package Body OCTOBER12LAB As
    Procedure convert(convID IN NUMBER, Measure IN NUMBER) Is
    V_Output Varchar2(50);
    Begin
    If convID = 1 Then
    V_Output := FeetToYards(Measure);
    elsIf convID = 2 Then
    V_Output := YardsToFeet(Measure);
    End If;
    DBMS_OUTPUT.PUT_LINE(V_Output);
    End convert;
    Function FeetToYards(Measure IN NUMBER) return varchar2 Is
    V_Total NUMBER(30,10); V_Output Varchar2(50);
    Begin V_Total := Measure/3; V_Output := Measure || ' Feet equals ' || V_Total || ' Yards'; Return V_Output; End FeetToYards;
    Function YardsToFeet(Measure IN NUMBER) return varchar2 Is
    V_Total NUMBER(30,10); V_Output Varchar2(50);
    Begin V_Total := Measure * 3; V_Output := Measure || ' Yard(s) equals ' || V_Total || ' Feet'; Return V_Output; End YardsToFeet;
    End OCTOBER12LAB;
    Begin
    OCTOBER12LAB.convert(1,3);
    OCTOBER12LAB.convert(2,2);
    OCTOBER12LAB.convert(1,5); End;
    Thanks in advance for your help.

    Hi
    Welcome to the forum!
    966784 wrote:
    After creating this bit of code for c_Pi
    SQL> create or replace package MATH_CONSTANTS is
    c_Pi constant number := 3.14159265; end MATH_CONSTANTS;
    Create an unnamed block of code which prompts the user for a single numeric parameter, v_radius. This module should calculate the area of a circle using a radius equal to the inputted value along with c_Pi from the MATH_CONSTANTS package and subsequently display this information in a meaningful manner to the user.
    Essentially how would I be able to take the user input and put it in a manner meaningful to the user (i.e. show it in a DBMS_OUTPUT.PUT_LINE(V_radius))If this is a homework assignment, ask your teacher for clarification of what this means.
    PL/SQL has no mechanism for promting the user and getting keyboard input. You'll have to do that through your front end. If you're using SQL*Plus, you can use the SQL*Plus ACCEPT command to prompt the user, get input and store it in a substitution variable.
    Also
    For this following code, will it work Try it and see.
    and if not how should it be changed around?
    Create or Replace Package OCTOBER12LAB As
    procedure CONVERT(convID IN NUMBER, Measure IN NUMBER); end OCTOBER12LAB;
    Create or Replace Package Body OCTOBER12LAB As
    Procedure convert(convID IN NUMBER, Measure IN NUMBER) Is
    V_Output Varchar2(50);
    Begin
    If convID = 1 Then
    V_Output := FeetToYards(Measure);
    elsIf convID = 2 Then
    V_Output := YardsToFeet(Measure);
    End If;
    DBMS_OUTPUT.PUT_LINE(V_Output);
    End convert;
    Function FeetToYards(Measure IN NUMBER) return varchar2 Is
    V_Total NUMBER(30,10); V_Output Varchar2(50);
    Begin V_Total := Measure/3; V_Output := Measure || ' Feet equals ' || V_Total || ' Yards'; Return V_Output; End FeetToYards;
    Function YardsToFeet(Measure IN NUMBER) return varchar2 Is
    V_Total NUMBER(30,10); V_Output Varchar2(50);
    Begin V_Total := Measure * 3; V_Output := Measure || ' Yard(s) equals ' || V_Total || ' Feet'; Return V_Output; End YardsToFeet;
    End OCTOBER12LAB;Never write, let alone post, unfomatted code.
    Which do you think is easier to read and understand? The package spec you posted above, or the version below? Which do you think will result in fewer bugs? If there are bugs, which do you think will be help you find them better? Which do you think will encourage people on this form to read and understand your questions?
    Create or Replace Package Body OCTOBER12LAB As
    Procedure convert ( convID     IN   NUMBER
                  , Measure    IN   NUMBER
    Is
        V_Output Varchar2(50);
    Begin
        If convID = 1 Then
            V_Output := FeetToYards (Measure);
        elsIf convID = 2 Then
            V_Output := YardsToFeet (Measure);
        End If;
        DBMS_OUTPUT.PUT_LINE(V_Output);
    End convert;
    Function FeetToYards ( Measure   IN    NUMBER)
    return       varchar2
    Is
        V_Total     NUMBER (30, 10);
        V_Output     Varchar2 (50);
    Begin
        V_Total := Measure / 3;
        V_Output := Measure || ' Feet equals '
                            || V_Total
                   || ' Yards';
        Return V_Output;
    End FeetToYar;
    Function YardsToFeet ( Measure    IN    NUMBER)
    return       varchar2
    Is
        V_Total     NUMBER (30, 10);
        V_Output     Varchar2 (50);
    Begin
        V_Total := Measure * 3;
        V_Output := Measure || ' Yard(s) equals '
                            || V_Total
                   || ' Feet';
        Return V_Output;
    End YardsFeet;
    End OCTOBER12LAB;The difference between what you posted and what I posted is merely whitespace; I didn't change your code at all except for adding spaces and newlines.
    Indent your code to show the extent of structural statements, like BEGIN and IF, and also to make long expressions (such as the multi-part || operations) easier to read and debug.
    Noramlly, all functions are included in the package spec. If you didn't want users calling a function directly (say, for security reasons) then you include the function in the package body only. Is there any reason not to include these functions in the package spec?
    When using dbms_output, remember to SET SERVEROUTPUT ON.
    Begin
    OCTOBER12LAB.convert(1,3);
    OCTOBER12LAB.convert(2,2);
    OCTOBER12LAB.convert(1,5); End;
    Thanks in advance for your help.Edited by: Frank Kulash on Oct 21, 2012 6:54 PM

  • General SQL question

    I have seen the following in some sql, but not sure of the difference.
    select abc, NULL from xyz where .....
    select abc, to_char(NULL) from xyz where ....
    my question is there a difference between NULL and TO_CHAR(NULL) ?
    Thanks.

    BluShadow wrote:
    Looks like someone was trying to cast the null to a varchar2 datatype so that SQL knew the datatype of the column. In that case they should have used the CAST function...
    Blu:
    Just out of curiosity, any particular reason for the preference for cast instead of to_datatype(null)? I often use that construct, particularly in union type queries. The cast is sematically meaningless in a union query since the column will get the size of the largest column in the query.
    SQL> set null null
    SQL> select *
      2  from (select 1 id, null c1, to_char(null) c2, cast(null as varchar2(10)) c3 from dual
      3        union all
      4        select 2, 'Hello there', 'Hello there', 'Hello there' from dual);
            ID C1          C2          C3
             1 null        null        null
             2 Hello there Hello there Hello there
    SQL> create view v as
      2  select *
      3  from (select 1 id, null c1, to_char(null) c2, cast(null as varchar2(10)) c3 from dual
      4        union all
      5        select 2, 'Hello there', 'Hello there', 'Hello there' from dual);
    View created.
    SQL> desc v;
    Name               Null?    Type
    ID                          NUMBER
    C1                          VARCHAR2(11)
    C2                          VARCHAR2(11)
    C3                          VARCHAR2(11)About the only place where I would use an explicit cast is if I was "hiding" the content of a column in a view, but needed to maintain the same structure as the table.
    John

  • SQL Questions (New to Cisco)

    Hello. I work for Clarian Health in Indianapolis and am trying to learn as much as possible about the SQL databases, both AWDB and HDS so that I can handle the reporting for our Revenue Cycle Customer Service.
    I am currently working my way through the Database Schema Handbook for Cisco Unified ICM /Contact Center Enterprise & Hosted. I’m also reviewing the explanation pages that are available for the reports on WebView. During my reviews, I have noticed a few things that confuse me.
    My questions are:
    1. Why do a majority of the tables on our SQL Server start with “t_”?
    2. Why do some of the tables have data on the AWDB server but not on the HDS server, and vice versa? (Examples: t_Agent and t_Agent_Team and t_Agent_Team_Member and t_Person are blank on the HDS database but not blank on the AWDB database; but the t_Agent_Logout is blank on the AWDB database and not blank on the HDS database)
    3. When data is moved to the HDS server every 30 minutes, is it also removed from the corresponding AWDB table?
    4. In review of the agent26: Agent Consolidated Daily Report syntax info located on the WebView, 1 of the calculations uses the LoggedOnTimeToHalf from the Agent_Half_Hour table while the remaining calculations uses the same field from the Agent_Skill_Group_Half_Hour table. Can you please tell me why this is? Why would all of the percent calculations not use the data from the same table? (The % of time Agent paused and/or put a task on hold uses the Agent_Half_Hour Table. All other % calculations uses the same field from the Agent_Skill_Group_Half_Hour Table.)
    5. Also in reviewing the agent26: Agent Consolidated Daily Report syntax info, I noticed that it contains the Skill_Group table, the Agent_Half_Hour table and the Media_Routing_Domain table. Both the Skill Group table and the Agen_Half_Hour table contain links to the Media_Routing_Domain table. Which relationship/join is actually utilized for this report?
    6. Why doesn't the LoggedOnTimeToHalf field on both the Agent_Half_Hour table and the Agent_Skill_Group_Half_Hour table have the same value in them?
    7. On the agent_26: Agent Consolidated Daily Report syntax explanation page, the Agent State Times: Log on Duration says that it is derived using the Agent_Half_Hour.LoggedOnTimeToHalf field, but when i convert this field to HH:MM:SS, it does not match the actual WebView report. But, when I use the Agent_Skill_Group_Half_Hour.LoggedOnTimeToHalfHour, it does match. Which one is correct?
    8. On the agent_26: Agent Consolidated Daily Report, why does the Completed Tasks: Transfer Out contain both the TransferredOutCallsToHalf and the NetTransferredOutCallsToHalf fields? What's the difference between the two? What Transfer out data writes to each field?
    Thank you.
    Angie Combest
    Clarian Health
    [email protected]

    You need to be careful when looking at the three databases - Logger, AW, HDS - which use the same schema. But many of what appear to be tables in the AW are really views into the t_ tables in the HDS - the data is not there in the AW DB. You are right to look at the schema - but check with SQL Enterprise to understand a bit more.
    In essence, the AW DB is for configuration data and real-time data. The HDS is for historical data. You can query the AW DB for (say) Call_Type_Half_Hour data and join with the Call_Type table to resolve the call type ID into its name - but the data is really in the HDS through the view.
    The DB design is quite complex and sophisticated - many things are not obvious.
    Keep up your research.
    Regards,
    Geoff

  • SQL question- on how to handle groups of records at a time.

    Hi,
    I have a sql that looks like the following:
    insert into INVALID_DATES_TMP
    (id, gid, created, t_rowid, updated)
    select id, gid, created, rowid, updated
    from TABLE1
    where fix_invalid_date_pkg.is_date_invalid('TABLE1', 'CREATED', ROWID) = 'Y';
    COMMIT;
    What the above sql does is selects all rows from TABLE1 where the CREATED column
    has invalid dates and inserts them into invalid_dates_tmp table. So we can process/fix
    those invalid dates from the temp table. Problem is our DBA said Table1 can have
    millions of rows so the above sql can be very database intensive. So, I need to
    figure out another way that may handle chunks of rows at a time from table1.
    Any ideas are appreciated!
    ThankYou,
    Radhika.

    Hallo,
    in general INSERT AS SELECT is the fastest method to insert into the table.
    Probably you can use direct load ? (Hint APPEND).
    Other options (INSERT IN LOOP or BULK + FORALL) are slower.
    I think, this method is optimal.
    Another question is, the function itself. It is not clear, whether it searches the invalid dates optimal. I suppose strong, that function uses dynamic SQL.
    Why ? It is better to search static . Or you use this function for many other columns ? Could you post the function also ?
    Regards
    Dmytro

  • Parent - child table issue wrt to count - SQL question

    I have a scenario:
    There are 2 tables (parent and child). lets say, case summary table and task level dimension table.
    for every case id in case summary table, there would be multiple tasks in task level dim table with a flag indicator set to 1 for all tasks.
    but while counting the number of cases active with flag indicator 1 (ofcourse when joining case summary table with task dimension table), for a case id only 1 instance of task needs to be accounted (even though it has more than one task , for counting active cases, the flag ind corresponding to a task in a case if set to 1 , then the case is considered active)..but while joining and taking count of case ids with flag indicator as 1, you get the count of every task row of a case which is incorrect logically. how to discard the rest of child records of a case in child table (task dimension table)?
    I am not sure how to achieve this in sql query
    Kindly help!
    Case summary table
    case id, busininess_unit, agent_name
    1001, admin, Ram
    1002, Finance, Sam
    task table
    case id, task_id,task_name, flag_indicator
    1001, 1, 'New', 1
    1001,2, 'Open',1
    1001,3,'In progress',1
    1002, 4, 'New', 1
    (In fact task_id is not a big deal... even you can assume task id doesn't exist..only task name ... )
    now my question... if my query should get the current active cases (ind=1); as per above it should essentially give 2... but my query gives me 4..you know the reason why.. but how do i get the correct count?
    Thanks!

    may be you need just this:
    select count(distinct case_id) from task
    where indicator = 1;
    If this is not what you are looking for, please elaborate and tell us the expected output and rest of the details as mentioned in FAQ Re: 2. How do I ask a question on the forums?:

  • SQL question - please help!

    Hi,
    I am working on a SQL, please help ms with the question
    below .... thanks
    (1)Increase by 10% salary of these captain pilots who have
    traveled more than 800,000 miles.
    Routes | | Flights | |Pilots |
    | | | | |
    #routeID | | #flightNO | |#pilotID |
    depAirportID |        |  airplaneNO| |*name |
    arrAirportID |_______/|  pilotID |\___________|*hours_in_air|
    length       |       \|  routeID |/ |*grade |
    ______________| |_____________| |*salary |
    |____________|

    If the length column in routes is in hours, and it represents
    additional hours to those shown in hours_in_air in pilots, then
    the following should work:
    UPDATE pilots
    SET salary = salary * 1.1
    WHERE pilotid in (SELECT a.pilotid
    FROM pilots a,
         (SELECT b.pilotid,sum(c.length) new_hours
          FROM flights b, routes c
          WHERE b.routeid = c.routeid
          GROUP BY b.pilotid) d
    WHERE a.pilotid = d.pilotid and
          new_hours + hours_in_air >= 80000)I suspect that you probably need to add additional criteria to
    the sub-query from flights and routes to take into account only
    flights since the hours_in_air column from pilots was last
    updated. However, your table structures do not indicate any
    date sensitivity. If the table flights is emptied every time
    hours_in_air is updated, then the query above will work.

  • SQL Question (Select rows with multiple records)

    Hello Gurus,
    I am learning SQL and have a question. Thanks for your time and help.
    I have 2 tables TABLE_AA and TABLE_BB. Both tables have two columns ID, DATA.
    TABLE_AA is connected to TABLE_BB through ID field (TABLE_AA.AA_DATA = TABLE_BB.BB_DATA)
    TABLE_AA
    ~~~~~~~
    AA_ID______AA_DATA
    ~~~~~~~~~~~~~~~~
    1111_______XXXX
    2222_______QQQQ
    3333_______ZZZZZ
    4444_______PPPPP
    ~~~~~~~
    TABLE_BB
    ~~~~~~~
    BB_ID BB_DATA
    ~~~~~~~~~~~~~~~~
    1111_______AAAA
    2222_______BBBB
    3333_______CCCC
    3333_______DDDD
    4444_______EEEE
    I am looking to get those AA_ID values that have multiple in TABLE_BB for their parent reference in TABLE_BB.
    So, from the above example, the sql should return the following as AA_ID 3333 has more than 1 reference value in BB_ID
    AA_ID_____BB_ID
    ~~~~~~~~~~
    3333______CCCC
    3333______DDDD

    Hi,
    It's working fine. !!
    14:10:05 topgun>With a As
    14:10:06   2   (
    14:10:06   3   Select 1111 c1, 'AAAA' c2 From dual Union All
    14:10:06   4    Select 2222 ,   'BBBB'    From dual Union All
    14:10:06   5    Select 3333 ,   'CCCC'    From dual Union All
    14:10:06   6    Select 4444 ,   'DDDD'    From dual
    14:10:06   7   ), b As
    14:10:06   8    (
    14:10:06   9    Select 1111 c1,'AAAA' c2 From dual Union All
    14:10:06  10   Select 2222 ,  'BBBB'    From dual Union All
    14:10:06  11   Select 3333 ,  'CCCC'    From dual Union All
    14:10:06  12   Select 3333 ,  'DDDD'    From dual Union All
    14:10:06  13   Select 4444 ,  'EEEE'    From dual
    14:10:06  14    )
    14:10:06  15   Select c1,
    14:10:06  16           c2
    14:10:06  17     From
    14:10:06  18       (
    14:10:06  19       Select a.c1,
    14:10:06  20              b.c2,
    14:10:06  21             Count(*) over (Partition By a.c1 Order By a.c1) cnt
    14:10:06  22      From  a,
    14:10:06  23             b
    14:10:06  24       Where a.c1 = b.c1
    14:10:06  25        )
    14:10:06  26   Where cnt = 2;
            C1 C2
          3333 CCCC
          3333 DDDD- Pavan Kumar N

Maybe you are looking for

  • Not able to send pdf file as attachment in my apple mail.

    Hi, I was easily able to attach pdf files to my apple mail.  infact I could just open a pdf file and then send it as attachment in the email earlier. but after downloading and upgrading to os X Mountain lion, I am neither being able to attach and sen

  • Limit records in nested repeat region

    I am using the nested repeat region behaviour and I need to limit the amount of records in the detail table. in ADDT it guides you through a wizard for master and detail tables to use this nesting which works great but it also returns all the records

  • Dlls are not working for me in Report server

    Hi, I am using SSRS 2008 and deployed some reports to the report server. For localization purpose we are having some Dlls which need to be registered in the report server. I am using some methods from the dll. Can someone please suggest how I can reg

  • CUA has lot of problems !! Please help

    Hello all, We have 10 systems(multiple clients in few systems) configured in CUA. Sometimes the roles dont get replicated, sometimes the IDOCs are not passed from parent to child, I added a new system to the Parent CUA and when I was assigning roles

  • Write back error, help

    Hi all, In my write back report, i got this error: error code: OPR4ONWY:U9IM8TAC:OI2DL65P 状态: HY000. 代码: 10058. [NQODBC] [SQL_STATE: HY000] [nQSError: 10058] A general error has occurred. [nQSError: 27024] The EXECUTE PHYSICAL statement must specify