SQL & PL/SQL :: Collapse All Nulls For Every Table Column In Statement?
Jul 19, 2013How do I collapse all nulls for every table column in a SQL Statement?
View 15 RepliesHow do I collapse all nulls for every table column in a SQL Statement?
View 15 RepliesI have a sql like 
select TRIM(column_name)
from user_tab_columns
where table_name = 'MTL_SYSTEM_ITEMS_VL' AND COLUMN_NAME   IN ('DESCRIPTION     ');
[Code]....
Like this i have many rows. What clause other than trim i should apply to no cosider the spaces?
I have a table with 5 columns: Region, Country, total number of visitors, language, popularity.
The table is populated with various regions, countries and values. I want to display this information in the form of report in the following format:
#Visitors          Language            Popularity
 Region +Country Region will be Europe, when the plus sign (+) against the country, France is clicked, the list should be expanded and display the country names such as Switzerland, Dublin, France, Germany etc. At the same time, before the list is not expanded the #Visitors , Language and Popularity should display the total sum for Region, Europe, whereas when the country (+) is clicked the values should be split across.
Ex:
 #Visitors          Language            Popularity
 Europe                100                 100                     100
    +France          
 #Visitors          Language            Popularity
 Europe 
    - Swiss           30                   30                       30
    - France          30                   30                       30
    - Germany         40                   40                       40
How this can be done in APEX?
HOW to use variable  P_TMPLID  in following statement
TYPE typ_unrecon IS TABLE OF REC_' || P_TMPLID ||'_UNRECON%ROWTYPE index by binary_integer;
because its throwing error while compiling
and also in statement
FORALL i IN unrecondata.FIRST .. unrecondata.LAST SAVE
EXCEPTIONS
--STRSQL := '';
--STRSQL :=  ' INSERT INTO REC_' || P_TMPLID ||'_UNRECON  VALUES ' || unrecondata(i);
--  EXECUTE IMMEDIATE STRSQL;
INSERT INTO REC_' || P_TMPLID ||'_UNRECON  VALUES  unrecondata(i);---throwing error on this statement
commit;
--dbms_output.put_line(unrecondata(2).TRANSID);
EXCEPTION
I AM HAVING A TABLE WITH BELOW STRUCTURE AND VALUES.
Table A
Col1Col2 Col3 
M1D1V1
M1D2
M1D3V2
M1D4
M1D5
[Code]...
Below is the scenario provided with sample data to replicate the actual requirement.
I am trying to write a query to get below output. But I am not able to succeed.
The column having null values should have the non null value as showed in example.
OUTPUT
------
Col1Col2 Col3 
M1D1V1
M1D2v1
M1D3V2
M1D4v2
M1D5v2
M1D6v2
M1D7V3
[Code]...
Below is the script for table and values
create table tmp (col1  varchar2(10),col2 varchar2(10),col3 varchar2(10));
insert into TMP (COL1, COL2, COL3)
values ('M1', 'D1', 'V1');
insert into TMP (COL1, COL2, COL3)
values ('M1', 'D2', null);
[Code]...
Am trying to extract data from oracle onto flatfile(.txt), am using UTL_FILE but, NULLs in oracle tables are getting converted into space and if i try loading into table it is getting loaded as space,
View 1 Replies View RelatedThis is a simple question, but I cannot seem to find a solution.  Here's the basic query:
select distinct accountno, parcelno, streetno||' '|| predirection ||' '|| streetname||' '|| streettype||' '|| postdirection||' '|| unitname||', '|| propertycity
from tblacctpropertyaddress ....
What I want to do is add is this logic:  If Predirection is null, then no space between streetno & streetname.  Same for postdirection and unitname.  (for example, if both postdirection and unitname are null, there are no spaces between streettype and the comma before propertycity)
 Also, when unitname is not null, I want to add the string "Unit " prior to the returned value in unitname.
I'm on 11.2.0.3.  I want to write a query to get calculate a running total of incidents per day - this query will be used for an APEX line chart.Sample table and data:
create table sales (
  id number primary key,
  time_of_sale date,
  item varchar2(20));
insert into sales values (1, to_date('02-JAN-2013','DD-MON-YYYY'), 'book'); ....
Are NULLs get indexed in bitmap indexes? How can I verify that.
View 3 Replies View RelatedWe have data as below in the table. I need the to display the records in the order based on number of NULL values and position for each record.
provide a simple query using case in ORDER BY clause.
ID     CLASS  NAME   DIST_ID  DIST_NAME
0      NULL   KIRAN   0        AP
0      C1213  NULL    0        AP
0      NULL   NULL    0        AP
NULL   C1234  NULL    0        AP
0      NULL   NULL    0        AP
NULL   NULL   NULL    NULL     NULL
0      C123   RAJESH  0        AP
NULL   C123   RAVI    NULL     AP
We have to give the rank based on NULL values and NULL value column position.Let us assume column positions as 
1    2     3     4      5
ID  CLASS NAME DIST_ID DIST_NAME
for the following three records number of NULL values are same. but positions are different.
0      NULL   NULL    0        AP   
NULL   C1234  NULL    0        AP     
0      NULL   NULL    0        AP     
NULL   C123   RAVI    NULL     AP     
Based on the column positions  the ranks as
                                 2*2+3*3=13
 1*1+3*3=10
                                 2*2+3*3=13
 1*1+4*4=17
Which is having high rank (greatest number) that record should come last . The record which is having all values that should come first. The record which is having all NULL values should come last. The out put I want as 
ID     CLASS  NAME   DIST_ID  DIST_NAME
0      C123   RAJESH  0        AP
0      NULL   KIRAN   0        AP
0      C1213  NULL    0        AP
NULL   C1234  NULL    0        AP
0      NULL   NULL    0        AP
0      NULL   NULL    0        AP
NULL   C123   RAVI    NULL     AP
NULL   NULL   NULL    NULL     NULL
While updating a table, is it possible to get the old value of a column.  I need to get it inside a PLSQL block and not in a trigger.for example :- 
DECLARE   
l_amountNUMBER(5) := 0;
BEGIN
UPDATECustTransactions
SETamount  = 150
WHEREcust_id = 5412
RETURNING amount INTO l_amount;
DBMS_OUTPUT.PUT_LINE ( 'l_amount= ' || l_amount );
END;
By using the RETURNING clause i am getting the new updated  value.  I need the old value for some processing.  Do i have to explicitly query it before the update stmt? Pls reply.
I have to conditionally update a set of columns in a table. If the column status_code_stage_3 IS NULL THEN I have to update the column status_code_stage_2. The below query is giving error:-
Test Table create scripts
CREATE TABLE test11( date_stage_3 date, reason_code_stage_3 varchar2(20),
 reason_code_stage_2 varchar2(20), opportunity_date date )
  INSERT INTO test11 values(sysdate,'reason1',NULL,sysdate)
  INSERT INTO test11 values(sysdate,NULL,'reason2',sysdate)
[code]....
how to work out the update statement to use the conditional statement for columns.
just i want add diiferece column in my select statement.For Example:-
select 
Name,
Salary,
Designation,
date_first_payment,
date_last_payment,
(date_first_payment-date_last_payment) Datediff
from My_table
 
then its working
select *,(date_first_payment-date_last_payment) Datediff
from My_table
its not working..
I have oracle table with a column of datatype CLOB. In the clob column having the manipulation statements (update, insert) as records.
How to execute the statements exists in a clob column as records?
my table structure and one record is
CREATE TABLE ACTN_CFG_T
(
  OBJ_ID       NUMBER(32)                       NOT NULL,
  ACTN_ID      NUMBER(38)                       NOT NULL,
  ACTN_SEQ     NUMBER(2)                        NOT NULL,
  RU_DEF       CLOB                             NOT NULL
[code]....
I want to execute the update statement when i call the obj_id. I used the follwing procedure but error.
1 DECLARE 
2 V_ABC CLOB;
3 BEGIN
4 SELECT RU_DEF INTO V_ABC FROM ACTN_CFG_T WHERE OBJ_ID = 1625;
5 EXECUTE IMMEDIATE V_ABC;
6 END;
error is...
ORA-06550: line 5, column 20:
PLS-00382: expression is of wrong type
ORA-06550: line 5, column 2:
PL/SQL: Statement ignored
Is there a way of selecting the value of a previous column in a case statement, without having to duplicate. E.g.
 
SELECT prod_id as Product,
Some complex calculation... as Total,
CASE 
[Code]....
I do not want to re-write the same calculation in the else statement but just want it to be be the value of Total column.
I have table desc xx_testName     
Null     Type          
 -------- -------- -------------- 
COL1     NOT NULL NVARCHAR2(100)  COL2     NOT NULL NVARCHAR2(100) COL3     NOT NULL NVARCHAR2(100)
i am able to query select * from xx_test however if i query as select col1 from xx_test then it is giving error.
ORA-00904: "COL1": invalid identifier00904. 00000 -  "%s: invalid identifier"*
Cause:    *Action:Error at Line: 3,131 Column: 13  
Let me know how to query NVARCHAR2 column and how can we put in WHERE condition ?
I am encountering error in this code.
WHILE EXISTS ( SELECT * FROM tblOrgChart WHERE fxOrgID = v_chrTempKeyDept )
      LOOP
            v_intDept := CAST(v_chrTempKeyDept AS NUMBER) + 1 ;
            v_chrTempKeyDept := LPAD('',3 - LENGTH(CAST(v_intDept AS VARCHAR2)),'0') || CAST(v_intDept AS VARCHAR2) ;
      END LOOP;
Error: PLS-00204: function or pseudo-column 'EXISTS' may be used inside a SQL statement only
I was looking for a way to see if a default value for a procedure was passed NULL or it got NULL by default. [URL]
View 11 Replies View Relatedi have two questions.
 (1) how can i fill some value in a table column based on some existing column value automatically without user intervention. my actual problem is i have 'expiry date' column and 'status'. the 'status' column should get filled automatically based on the current system date. ex: if expiry date is '25-Apr-2011' and current date is '14-May-2011', then status should be filled as 'EXPIRED'
(2)hOw can i build 'select' query in a report (report 6i) so that it will show me list of items 'EXPIRED' or 'NOT EXPIRED' or both expired and not expired separately in a single report based on user choice. 'EXPIRED' & 'NOT EXPIRED' can be taken from the above question no. 1.
I am trying to update currency column of one table using the currency column of other table using the following sql code.
update ODS.SO_ITEM OSI
set CURRENCY__CODE=(select currency__code from sa_sales.SO_ITEM SSI where SSI.ID=OSI.ID)
This update is taking taking a lot of time and is never ending.
should i create index on source table (SA_SALES.SO_ITEM) or on target table (ODS.SO_ITEM) ?
I am writing a query and I did get it to work but it shouldn't be this hard, I feel like I am doing something wrong, and there has to be a more elegent solution.
This query works:
SELECT a.d
FROM (
     SELECT S_ID a, LOOKUP_DESC d, S_CODE f
     FROM SSS
     JOIN LOOKUP ON S_CODE LIKE LOOKUP_CODE
     UNION ALL
  
[Code]...
I feel like I should be able to execute the query like this: This query doesn't work:
SELECT a.d
FROM (
     SELECT S_ID a, LOOKUP_DESC d, S_CODE f
     FROM SSS
     JOIN LOOKUP ON S_CODE LIKE LOOKUP_CODE
 
[Code]...
 -- not some huge query
i want to select dynamic column names in my select statement in my function.
View 4 Replies View RelatedI want to know the DDL statements executed on a table.  Example:
i have a table test1 with structure as below: test1 (aa number, bb varchar2(10))
After some period of time, one DDL statement to alter the column is issued.
alter table test1 modify (bb varchar2(30));
so new table structure is: test1(aa number, bb varchar2(30))
Basically i would like to find these 2 DDL statements executed on this table - test1, so that i compare which column get modified and what modification done.
Is this information stored in any data dictionary table?
note - audit, flashback option not enabled in this database.
I have a table TEMP_TEST_1 to be loaded with multiple rows which contains the available items for a store with their sequence numbers. I also have another table TEMP_INV_1 which holds a column for inventory count of the items, and this column is to be updated after loading the first table TEMP_TEST_1.
The table TEMP_TEST_1 is updated through all possible channels in OLTP. So while updating the inventory, which is the best way. My update should either add the total number of inserts per item into the TEMP_TEST_1 table's INVENTORY_CNT column i.e. existing value + count of new rows OR a full update by taking the complete row count (Grouped by item id) and update the INVENTORY_CNT column
--------------------------------------------------------------------------------
-- Initial setup SQL's, TEMP_TEST_1 is updates on OLTP through multiple channels
--------------------------------------------------------------------------------
CREATE TABLE TEMP_TEST_1 ( ITEMID NUMBER ( 4 ),
INVENTORY_CNT NUMBER ( 2 ) );
CREATE TABLE TEMP_INV_1 ( ITEMID NUMBER ( 4 ),
ITEMSEQ NUMBER ( 5 ) );
INSERT INTO
[code].......
--------------------------------------------------------------------------------
-- Inserts for new items in the store
--------------------------------------------------------------------------------
INSERT INTO
TEMP_INV_1
VALUES
( 1,
11 );
INSERT INTO
TEMP_INV_1
[code].......
i'm trying to use a collection in a select statement as a table, but i've got an error which i don't understand.
This exemple is very simple. I'm trying to validate the solution. The object will contain the result of a query from a big table, and i have 4 request to make on it. I don't want to select 4 times the big table to get the result, but i need the whole result to make my requests (intersect, minus and union)
CREATE OR REPLACE
TYPE zy_w AS OBJECT(
CODE_INFORMATIONVARCHAR2(4),
[Code]....
****************
Rapport d'erreur :
ORA-06550: Ligne 12, colonne 3 :
PL/SQL: ORA-00947: nombre de valeurs insuffisant
ORA-06550: Ligne 5, colonne 3 :
PL/SQL: SQL Statement ignored
06550. 00000 -  "line %s, column %s:
%s"
*Cause:    Usually a PL/SQL compilation error.
*Action:
 this is the correct syntax for updating a table with a select statement included. Table created easily and the alter table ran fine, but the update is running quite a log time. 
My ultimate goal is to populate the "children" field with a count of children for each household id.
create table NON_GBC_Members nologging as 
       select distinct hcp.household_master_ID
       from mrtcustomer.household_child_profile hcp
       where hcp.child_birth_dt between '31-OCT-2000' and '30-OCT-2011'
       group by hcp.household_master_id
       minus 
[code]....
{code{
i want to apply merge stmt on single table.
CREATE TABLE TEST11(TNO NUMBER(5), TVAL VARCHAR2(100), TID VARCHAR2(10));
INSERT INTO TEST11 VALUES(1,'VIJAYA','TEST');
INSERT INTO TEST11 VALUES(2,'VIJAYA','TEST');
INSERT INTO TEST11 VALUES(3,'VIJAYA','TEST');
INSERT INTO TEST11 VALUES(4,'VIJAYA','');
INSERT INTO TEST11 VALUES(5,'VIJAYA','');
[Code]....
My requiremen is if record is exists then i wan to update some value, if record not existes the i wan to insert new record
there is a possible to use a select statement on collection table?
View 1 Replies View RelatedI have a table with a column type long raw. Now i want to insert an image from directory by an insert statement. Is it possible?
View 2 Replies View RelatedI have the following create table statement:
create table SELECTION_BOOKMARK(
INSTALLATION_ID SMALLINT NOT NULL,
BOOKMARK_ID SMALLINT NOT NULL,
NAME VARCHAR2(50) NOT NULL,
SORT_ORDER SMALLINT NULL
);
When I execute this statement as part of a SQL script, it throws the error "ORA-01003: no statement parsed".  If I execute it as a stand alone sql command, it returns no error.
Here's the strange thing, though.  Even when it throws the error message the table is created.  Later on in the script, I execute the following command:
alter table SELECTION_BOOKMARK add primary key(INSTALLATION_ID,BOOKMARK_ID);
This command also throws the above mentioned error, but once again the command executes - the primary key is created.Well, I don't like having a script that throws errors.  Eventually I'll have to give this script to a dba in another organization and I don't want my script to be throwing errors - even if it's apparently working correctly despite the errors.