SQL & PL/SQL :: Order By Field Containing Characters And Numbers (split From Convert No Rows Returned To Zero)
			Jan 13, 2012
				I Want to make a query to select finished goods product in sales having product code greater than 280 but i have face a problem that order by is not working because products column have character code as well as number. how to sort that column.
	
	View 2 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Mar 7, 2013
         I have a query that produces around 11 fields, and one of which is a multi-delimited field and the other 10 are dimension fields.  I would like to split that field into several rows, and have the other 10 fields just repeated for each one.  Here is an example of the data in the 11th field :
Column 11
34^56^78,59
There are two delimiters in the field, a carat and a comma.  This field is used to reference document numbers that are needed to be sent in.  The carat represents the word "Or" and the comma represents the word "And".  I would like to have the output of each field to be a repeat of the 10 dimension fields, plus 3 new fields.  The first new field would be the document number, the second new field would be the position within the original delimited field(1, 2, 3, etc.) , and the last field would be one of three logic words :First (if it is the first value), Or (if the value followed a carat), And (If the value followed a comma).  Example of the output from the above value would be :
Column 11   Column 12   Column 13
34_______  1_______   First
56_______  2_______   Or
78_______  3_______   Or
59_______  4_______   And
Any thoughts on this?  I have found a few solutions online on how to break up the delimited field into rows, but never with multiple delimiters or with extra logic for the added fields. 
	View 13 Replies
    View Related
  
    
	
    	
    	
        Jul 13, 2011
        I have a table test with column containing dates, characters and numbers. I have to extract the number part and the three characters before the number . My data looks like :
TEST
ID DATA
1  3/12/2007
2  0
3  3/8/2010 ABC 217
4  NONE
5  COLM XYZ 469 6/8/2011
6  LMN 209
My expected results should look like :
ID  DATA
1 
2  
3   ABC 217 
4
5   XYZ 469
6   LMN 209
	View 7 Replies
    View Related
  
    
	
    	
    	
        Oct 15, 2012
        For one of my row its returning as below lpad('abcdef', 4 , 'Z') returning abcd
but instead of this if no of characters is greater than 4 i want the actual data without lpad should be returned.
	View 7 Replies
    View Related
  
    
	
    	
    	
        May 28, 2013
        Oracle Version: 11gR2: 11.2.0.1.0 - 64bit
OS: Linux Fedora Core 17 X86_64
Currently, I'm reading the online book Oracle Concepts, Chapter 3: 3 Indexes and Index-Organized Tables, section: Reverse Key Indexes in order to understand this topic.
As I understand  for each pair of (key, rowid) in the index structure, the rowid for each row in the table obviously remains the same but the bytes of the key are reversed before the key is stored. So for example on a 32 bit machine (just an example) a key = 10 AB CD EF will be stored as FE DC BA 01 , am I right?
According to the documentation, this becomes interesting in RAC environments in order to remove a hot spot from the index (when multiple instances repeatedly modify the same block) with the disadvantage that in some cases there cannot be Index Range Scan any more as data in the index is not sorted by column key when it is stored.
I was just curious to see how bytes of each key are reversed and after a bit googling I found an article where Tom Kyte shows with an example by using dump function (which as I understand gives the internal representation of a given expression) the difference in the sequence of bytes. Here is the link
[URL]
So based on his instructions I tried to do my own test, yet I don't get the same result, that is, the bytes are not reversed for me once we rebuild the index by REVERSE key word.
I'm going to write down here the test that I did, where is/are my error(s)
Test Case: 
(I use a copy of the employees table in hr sample schema)
SQL> CREATE TABLE emp_test AS SELECT * FROM hr.employees;
Table created.
SQL> CREATE INDEX emp_test_idx ON emp_test(first_name);
[code]...
Now, a test SQL Query using the index we've just defined (just for giving an example)
SQL> SELECT first_name,
  2         dump(first_name, 16) as dump_result
  3  FROM emp_test
  4  WHERE first_name = 'Kelly';
FIRST_NAME                DUMP_RESULT
--------------      ----------------------------------
Kelly                 Typ=1 Len=5: 4b,65,6c,6c,79
[code]...
So, according to the above Execution plan, Oracle does an Index Range Scan using the index that I defined on my table that is, emp_test_idx. According to the output of dump, the key (first_name) in that index is stored (in terms of bytes) as 4b,65,6c,6c,79
SQL> SELECT chr(to_number('4b', 'xx')) ||
  2         chr(to_number('65', 'xx')) ||
  3         chr(to_number('6c', 'xx')) ||
  4         chr(to_number('6c', 'xx')) ||
  5         chr(to_number('79', 'xx')) first_name
  6  FROM DUAL;
FIRST_NAME
--------------------
Kelly
Which as we can see corresponds to the first name 'Kelly', the first name we specified in the above SQL query.
Now let's rebuild the index
SQL> ALTER INDEX emp_test_idx REBUILD REVERSE;
Index altered.
SQL> 
Once the index keys have been reversed, I run the very same query in order to see the difference
SQL> SELECT first_name,
  2         dump(first_name, 16) as dump_result
  3  FROM emp_test
  4  WHERE first_name = 'Kelly';
[code]...
So the second time after the index has been reversed, I still get the very same sequence of bytes, that is, 4b,65,6c,6c,79, whereas I expected to get 79,6c,6c,65,4b (that is, the reversed order of the initial bytes sequence)
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jan 10, 2011
        Need to write a function that should allow only characters and numbers in Login ID using pl sql.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jun 12, 2013
        A sample query to check  whether a string contains 2 upper characters and numbers are present in that character using regular_exp .
	View 12 Replies
    View Related
  
    
	
    	
    	
        Apr 23, 2009
        I need to update a field with the 1st 9 characters of another field in the same record.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 11, 2011
        I need to create a function where in data from 5 rows is clubbed into one row. Like this I have around 425 rows which should be clubbed to 85 rows. Requirement is similar to pivot but not exactly like a pivot as different columns need to be taken from those 5 rows. This is for reporting purpose in order to get data in the desired report format.
SQL mentioned below works fine. It does return data.When below code is used as a normal procedure with OUT parameter as Index by table of Record type code works fine. It returns data. Functionality is met. But when used as a pipeline function, it returns no data. 
Below code gets compiled but returns nothing. I didn't find anything on Google or any website for same. 
CREATE TYPE r_report_mth_rec_obj AS OBJECT (
   acct_num                         VARCHAR2 (20),
   acct_name                        VARCHAR2 (80),
   fund_group                       VARCHAR2 (80),
   fund_type                        VARCHAR2 (80),
   share_class_code                 VARCHAR2 (10),
   share_class_description          VARCHAR2 (20),
   curr_code                        VARCHAR2 (10),
  [code]...
	View 16 Replies
    View Related
  
    
	
    	
    	
        Sep 26, 2010
        difference in the values that are returned?
select count(*) from aaa;
  COUNT(*)
----------
   1000001
select num_rows from dba_tables where table_name = 'AAA';
  NUM_ROWS
----------
    994202
	View 5 Replies
    View Related
  
    
	
    	
    	
        Sep 17, 2010
        DECLARE
l_query VARCHAR2(4000);
TYPE cursor_type IS REF CURSOR;
[Code].....
How can I get the total number of rows returned by the query?
I want to be able to check omething like c1.ROWS = 0
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 21, 2013
        I have employees under a supervisor defines as below:
select LOGIN_USER_ID from APPWMS.VIEW_EMP_LATEST_INFO where SPVSR_LOGIN_USER_ID='erbrand' and EMP_STAT_CODE='ACTIVE'
Now I need to determine if all above employees are clocked in , clocked out or not clocked between yesterday and today using following:
select to_char(CLOCK_IN_DATE,'dd-mon-yyyy hh24:mi:ss' ) ClockIn,to_char(CLOCK_OUT_DATE,'dd-mon-yyyy hh24:mi:ss' ) ClockOut ,LOGIN_USER_ID,--CLOCK_IN_DATE,CLOCK_OUT_DATE, CLOCK_OUT_DATE-CLOCK_IN_DATE,trunc(sysdate) , trunc(sysdate-1),
case when CLOCK_OUT_DATE is null then
  'Not clocked out'
else
[code]....
The first SQL gives me 66 rows while second gives me 40 rows. For 26 people , no rows are returned which means these people donot have a clock in record between two timestamps.
How can we modify query to show those 26 people as 'Not clocked In'
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 5, 2013
        How Can I delete the returned two rows?
  1  select s.reg_no,s.course_code,
  2  s.section src_sec,a.section a_sec,a.att_date,a.att_flag
  3  from attendance a ,src s
  4  where a.semester_code=1
  5  and a.semester_year=2013
  6  and s.semester_code=1
  [code]....
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 6, 2010
        I want to convert numbers into hours and minutes.I have two numbers say like first number is 1234 and second number is 1235.4 now i want to find the different between these two numbers. so am subtracting number 2 - number 1
1235.4 - 1234 i will get 1.4 so the result of this 1.4 to be converted as hours and minutes like 1 hr and 40 minutes. How can i convert numbers in hrs and minutes.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jul 31, 2013
        In employees table I am having employee_name column data as follows 
Aaron, Mrs. Jamie (Jamie)Aaron, Mrs. Jenette (Jenette)Abbott, Ms. Rachel (Rachel) Breton, Mr. Jean  Britz, Mrs. Sarie (Sarie) --> Now, I want to display the employee name like "Mrs. Jamie" (with out Surname and with out bracket included text),--> 
How to achieve this by SQL query. 
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jan 31, 2013
        In this query split is a pipe line function to convert row(rows stored with , delimited) as columns like below
for ex for below query
SELECT  * from  TABLE(SPLIT('bbb003,bb004'));
out put is 
bbb003
bb004
now i have to apply same function on column,column is storing data with ',' separated.and i have tried like but it's throwing missing expression. how i can use this function on entire column from this table.
SELECT  * from  TABLE(SPLIT(select candidates FROM ibis.cw_uploads_inprogress ));
	View 7 Replies
    View Related
  
    
	
    	
    	
        Mar 22, 2010
        I need to separate 1 field into 2 fields. The source is varchar2 and is like:
[VOUCHER]
CGJ0000617
CG0001442
CGJ0001444
CMOV0000200
CXAR00000001
CXAR00000002
Result should seperate numeric value from characters so that the result would be:
[VOUCHER_char]             [VOUCHER_num]
CGJ                                  0000617
CG                                  0001442
CGJ                                  0001444
CMOV                               0000200
CXAR                                00000001
CXAR                                00000002
I need one or two SQL statement.
	View 9 Replies
    View Related
  
    
	
    	
    	
        Aug 22, 2011
        I am importing some data from Oracle into another database on a regular basis. It works fine for most of the queries but couple of queries don't work sometimes (random). I don't get any errors or any data. 
We switched on the Oracle auditing to find out the queries being sent to oracle db. We can see all the queries in the Audit log. Is it possible to configure Auditing to get the "Number of Rows" returned by Select statements so that we can be sure that some data was returned. 
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jun 23, 2013
        One table ACCOUNT_T.CREATED_T is number (38). It is mapped to /ACCOUNT's PIN_FLD_CREATED_T, which is timestamp. ACCOUNT_T table has one record, CREATED_T = 1362063600. This field is displayed at the GUI (Customer Center) as Feb 28, 2013 So my question, how to convert the number value (1362063600) to a date value (Feb 28, 2013)?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 19, 2012
        I am using Oracle Version 11.2. Here's an example of what I am trying to do..
-- create table with a clob column
create table sr_test
(c1 CLOB)
-- load data that is more than 4000 characters into clob
declare
var1 varchar2(32000);
begin
var1:= '';
for i in 1..5000 loop
var1:= var1||i||',';
end loop;
dbms_output.put_line(var1);
insert into sr_test(c1) values (var1);
end;
-- select table to make sure clob is loaded
select c1, dbms_lob.getlength(c1) from sr_test
-- create procedure to return data from table
create procedure sr_p1(result out sys_refcursor)
is
begin
open result for
select c1 from sr_test;
end;
-- run the procedure to get data
DECLARE 
RESULT sys_refcursor;
BEGIN 
RESULT := NULL;
ACCOUNTING.SR_P1 ( RESULT );
:rc0_RESULT := RESULT;
END; 
Everything works as intended. However, this procedure is being called from Webservices. According to what I have been told, webservices adds 18ms for each clob that needs to be converted into char so it can be displayed on the screen. So, I need something like this 
create procedure sr_p1(result out sys_refcursor)
is
begin
open result for
select dbms_lob.substr(c1,32000,1) from sr_test;
end;
Is there an alternate method to send more than 4000 characters in the refcursor?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 5, 2008
        The HTML code for the bracket character '[' is & # 91; (without spaces).  In my SQL, I would like to convert the word [you into & # 91;you.  Is there a way to do that?
I know that replace() will work, but with that you have to supply a list of chars to replace; I
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jan 29, 2009
        I have an Oracle 10g database, on the App Serv I have an image file that has 20,000 .jpg files that has an id number as each image name.I have successfully queryed the image file and posted one image to my web page matching the image id number.
sample:
select substr(spriden_last_name,1,20)||', '||
substr(spriden_first_name,1,20)||' '||
substr(spriden_mi,1,1) stname,
'<img src = "/images/&1..JPG" width="400" height="400"/>' pic
from spriden
where spriden_id = '&1'
/
the &1 is the matching id number that is input from the user.My task now is to select multiple images using a department field in the spriden table to pull the needed id numbers.I have not been successful in the proper format to pass the id number to the <img src field.
	View 4 Replies
    View Related
  
    
	
    	
    	
        May 2, 2012
        I have data like :
ID    NAME1    NAME2      NAME3
JJ          AD      MED
VI      TIBO    PH          TIBO
I want output like
ID          NAME
JJ          AD
JJ          MED
VI          TIBO
VI          PH
VI          TIBO
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 4, 2011
        SELECT 'TEST','F1,F2,F3,F4' from dual
I want to split the rows by comma separated as below
TEST F1
TEST F2
TEST F3
TEST F4
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 21, 2006
        I am using an Oracle view and package to extract data from my DB to build an XML file on the fly. 
My problem is that on very rare occasions, an invalid XML character will be in the database. This, of course, causes my XML file to error.
My question is: What are the possible ways to remove invalid XML characters when selecting out of a DB field? Any function that has been written for this type of thing, or is a VERY long 'translate' more of what I should be doing?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 15, 2013
        I have a table which stores Employees and their Phone numbers. Each employee can have multiple numbers e.g.
Employee, Number 
Adam, 123 
Adam, 456
John, 123
John, 456
I am trying to write a select statement that will split the rows into columns and group by each employee e.g.
Employee, Number1, Number 2
Adam, 123, 456
John, 123, 456
	View 19 Replies
    View Related
  
    
	
    	
    	
        Aug 6, 2013
        I have a table that has about 20,000 rows. 
There is a column called Keyword which has values like below: 
File_IDKeyword1SMITH;ALLEN;WARD;JONES; BRADY2S&P500;TOPIX3SMALL;LARGE;MEDIUM
 I want to output the data like this: FILE_IDKEYWORD1SMITH1ALLEN1WARD1BRADY2S&P5002TOPIXetc 
I'm using this query and it works: SELECT STG.FILE_ID, REGEXP_SUBSTR(STG.KEYWORD,'[^;]+', 1, LEVEL) AS KEYWORD FROM STG_TABLE STGCONNECT BY REGEXP_SUBSTR(STG.KEYWORD,'[^;]+', 1, LEVEL) IS NOT NULL 
But its sooooo slow, its unusable. Is there a quicker way to return this output? Other info:KEYWORD is varchar2(4000) but rarely more than 100 bytes are usedOracle 11g2 !
	View 5 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2013
        I am having an issue with clob_agg...ordered by a field.
with test_asg as (
                  select 100 ASSIGNMENT_ID, 'Comp info' TITLE, 'AP' EMP_CAT from dual union all
                  select  100,'Technician','AP'  from dual union all
                  select  101,'Faculty','AP'  from dual union all
                  select  102,'Teaching','CS'  from dual union all
[Code] .......
Here I need clob concatenation based on ordered assignment name...
op should be based on title in alphabetical order(1st character)..
For 102 it should be 
Grad Assist, Secretary, Teaching
G,S,T -- Alphabetical order
Code I tried : (didn't keep the data in the order)
with test_asg as (
                  select 100 ASSIGNMENT_ID, 'Comp info' TITLE, 'AP' EMP_CAT from dual union all
                  select  100,'Technician','AP'  from dual union all
                  select  101,'Faculty','AP'  from dual union all
                  select  102,'Teaching','CS'  from dual union all
[Code] ......
Clobagg function :
create or replace
type clobagg_type as object(
text clob,
static function ODCIAggregateInitialize(
sctx in out clobagg_type
[Code] ......
	View 8 Replies
    View Related
  
    
	
    	
    	
        Dec 12, 2010
        I have a name field like below; i need a query to display the name field in alphabetical order like in dictionary. 
Emp Name
--------
Sam
John
Noel
Alen
Saaem
output would be
---------------
Alen
John
Noel
Saaem
Sam
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 26, 2010
        I have a table like this:
ID1 ID2 Ini_date End_date
1 1 2008-05-14 2010-09-16
1 2 2010-01-21 2010-08-26
..... ..... ............. ...................
and I would like to have a row for each year between ini_date and end_date.
ID1 ID2 YEAR
1 1 2008
1 1 2009
1 1 2010
1 2 2010
	View 2 Replies
    View Related