help with pl SQL script
Hello everyone.
Can sb help me create the following script, based on three tables:
ID | col1 |
---|---|
314 | value2 |
ID | ID1 | col2 |
---|---|---|
314 | 1 | somevalue4 |
314 | 2 | somevalue5 |
314 | 3 | somevalue6 |
ID | ID1 | ID2 | COD | Qty. |
---|
The result should be like this:
id | id1 | ID2 | cod_1 | qty_1 | COD2 | qty_2 | col1 | col2 |
---|---|---|---|---|---|---|---|---|
314 | 1 | 1 | LTR | 10 | KG | 20 | value2 | somevalue4 |
314 | 2 | 1 | LTR | 40 | value2 | somevalue5 |
Post edited by: 933651
Hello
Here is my view on this problem. May need some adjustments in the join conditions when the data model and the data is more clear
create table t1 ( id number, col1 varchar2(10) ); insert into t1 values (314, 'somevalue2'); create table t2 ( id number, id1 number, col2 varchar2(10) ); insert into t2 values (314, 1, 'somevalue4'); insert into t2 values (314, 2, 'somevalue5'); insert into t2 values (314, 3, 'somevalue6'); create table t3( id number, id1 number, id2 number, cod varchar2(3), qty number ); insert into t3 values (314, 1, 1, 'LTR', 10); insert into t3 values (314, 1, 2, 'KG', 20); insert into t3 values (314, 2, 1, 'LTR', 40); with ltr as ( select id, id1, id2, cod, qty from ( select id, id1, id2, cod as code, cod, qty from t3 ) pivot ( sum(qty) for code in ('LTR' as qty) ) where qty is not null ), kg as ( select id, id1, id2, cod, qty from ( select id, id1, id2, cod as code, cod, qty from t3 ) pivot ( sum(qty) for code in ('KG' as qty) ) where qty is not null ) select t2.id, t2.id1, ltr.id2, ltr.cod, ltr.qty, kg.cod, kg.qty, t1.col1, t2.col2 from t2 join ltr on ( t2.id = ltr.id and t2.id1 = ltr.id1 ) full join kg on ( t2.id = kg.id and t2.id1 = kg.id1 ) left join t1 on ( t1.id = t2.id ) order by id, id1 ; drop table t1 purge; drop table t2 purge; drop table t3 purge; table T1 created. 1 rows inserted. table T2 created. 1 rows inserted. 1 rows inserted. 1 rows inserted. table T3 created. 1 rows inserted. 1 rows inserted. 1 rows inserted. ID ID1 ID2 COD QTY COD QTY COL1 COL2 ---------- ---------- ---------- --- ---------- --- ---------- ---------- ---------- 314 1 1 LTR 10 KG 20 somevalue2 somevalue4 314 2 1 LTR 40 somevalue2 somevalue5 table T1 dropped. table T2 dropped. table T3 dropped.
Tags: Database
Similar Questions
-
Hello experts.
I have the following example stored procedure
create or replace procedure as bingo
Start
dbms_output.put_line ('Bingo!');
end;
Now, I would like to create more of them, but that giving different names
So I would like the following
create or replace procedure bingo_ 2 as
Start
dbms_output.put_line ('Bingo!');
end;
create or replace procedure bingo_3 as
Start
dbms_output.put_line ('Bingo!');
end;
I'm writing a dynamic statement to make, but I'm running into a bit of problem. Help, please. See my code below
Declare
XP varchar2 (4000);
GH varchar2 (4000);
Start
Select dbms_metadata.get_ddl ('PROCEDURE', 'BINGO', 'TEST_MFG') in xp
Double;
immediately run xp;
end;
The problem with my code so far, I'm having a time difficult obtaining the first line that contains the name so that I am change the name and it concatenates back to metadata.
Thank you.
Hello
If what you want is to create the BINGO_2 procedure the same as the procedure BINGO
Try the following
DECLARE
XP VARCHAR2 (4000);
GH VARCHAR2 (4000);
BEGIN
SELECT REPLACE (dbms_metadata.get_ddl ('PROCEDURE', 'BINGO', 'TEST_MFG'), 'BINGO', 'BINGO_2')
IN xp
DOUBLE;
EXECUTE immediate xp;
END;
/
concerning
Salim
-
Hello
I have a data in table (raj_table) with columns (char11) raj_id, raj_number (varchar2 (15)), raj_format (NUMBER), Primary_ID (identity with the values of the primary key column)
Primary_ID raj_id Raj_number Raj_format
1 raj rajvend 1
2 raj rajvend 1
3 raj rajvendor1 2
4 raj rajvendor1 2
5 raj rajvendor1 2
6 raj rajvendor2 3
I used under SQL to get query output as below, but has not achieved the required result:
Select client_id vendor_number, vendor_format, primary_id, row_number() on sl_no (client_id partition, primary_id, vendor_format order of client_id primary_id, vendor_format, vendor_number, vendor_number)
from raj_table by sl_no asc
SL_NO raj_id raj_number raj_format primary_id
1 1 raj rajvendor 1
1 2 raj rajvendor 1
2 3 raj rajvendor1 2
2 4 raj rajvendor1 2
2 5 raj rajvendor1 2
3 6 raj rajvendor2 3
I need help with a SQL query to get the result as above without using the group by clause. I want to bring together the combination of separate line of the three columns (raj_id, raj_number, raj_format) and add a unique serial number for each online game (SL_NO column below). So, above there are 3 unique set of (raj_id, raj_number, raj_format) I can get in a group by clause, but I can not add prmiary_id, SL_NO values if I group by clause. I used the analytical functions like row_number() but no luck. Need solution for this.
with t as)
Select 'raj' raj_id, 'rajvend' raj_number, 1 raj_format, 1 primary_id Union double all the
Select option 2, 'raj', 'rajvend', 1 double Union all
Select 3, 'raj', 'rajvendor1', 2 double Union all
Select 4, 'raj', 'rajvendor1', 2 double Union all
Select 5, 'raj', 'rajvendor1', 2 double Union all
Select 6, 'raj', 'rajvendor2', 3 double
)
Select dense_rank() over (order of raj_id, raj_number, raj_format) sl_no,
t.*
t
order by primary_id
/
PRIMARY_ID RAJ RAJ_NUMBER RAJ_FORMAT SL_NO
---------- ---------- --- ---------- ----------
1 1 raj rajvend 1
1 2 raj rajvend 1
2 3 raj rajvendor1 2
2 4 raj rajvendor1 2
2 5 raj rajvendor1 2
3 6 raj rajvendor2 36 selected lines.
SQL >
SY.
-
Help with making SQL query references to column aliases in the Case statement
I need help with a sql query that I'm trying. I can go about it the wrong way, but I would be grateful if I could get any suggestions on possible solutions. This is my query:
SELECT DISTINCT spriden_pidm, spriden_id id, spriden_last_name | ',' | spriden_first_name name,
CASE
WHEN rcresar_comm_code_01 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_01
WHEN rcresar_comm_code_02 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_02
WHEN rcresar_comm_code_03 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_03
WHEN rcresar_comm_code_04 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_04
WHEN rcresar_comm_code_05 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_05
WHEN rcresar_comm_code_06 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_06
WHEN rcresar_comm_code_07 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_07
WHEN rcresar_comm_code_08 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_08
WHEN rcresar_comm_code_09 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_09
WHEN rcresar_comm_code_10 IN ('268 ', '269', ' 270') THEN rcresar_comm_code_10
END acg_elig_comm_code
CASE
WHEN acg_elig_comm_code = ' 268' THEN 'rigorous HS course. "
WHEN acg_elig_comm_code = '269' THEN ' 2 or several AP or IB"
WHEN acg_elig_comm_code = '270' THEN 'NOC as possible ".
END comm_code_description
OF spriden, rcresar, rcrapp1
WHERE (rcresar_comm_code_01 IN ('268 ', '269', ' 270')
OR rcresar_comm_code_02 ('268 ', '269', ' 270')
OR rcresar_comm_code_03 ('268 ', '269', ' 270')
OR rcresar_comm_code_04 ('268 ', '269', ' 270')
OR rcresar_comm_code_05 ('268 ', '269', ' 270')
OR rcresar_comm_code_06 ('268 ', '269', ' 270')
OR rcresar_comm_code_07 ('268 ', '269', ' 270')
OR rcresar_comm_code_08 ('268 ', '269', ' 270')
OR rcresar_comm_code_09 ('268 ', '269', ' 270')
OR rcresar_comm_code_10 ('268 ', '269', ' 270'))
Rcresar_aidy_code = & aidy_code
AND rcrapp1_aidy_code = rcresar_aidy_code
AND rcrapp1_curr_rec_ind = 'Y '.
AND rcrapp1_seq_no = rcresar_seq_no
AND spriden_pidm = rcresar_pidm
AND rcrapp1_pidm = rcresar_pidm
AND spriden_change_ind IS NULL
ORDER BY name
The second case statement is where I don't know exactly what it takes to get what I want.
Output should be like:
spriden_pidm name ID acg_elig_comm_code comm_code_description
«0000000000', ' 1111111111 ","John Doe","268", «rigorous HS race"»
If I take the second case statement it works great except that I do not have my comm_code description column. My question is how can I use my first statement value box to determine this column? I think that I need a case statement as I have, but I don't know how to reference the value of acg_elig_comm_code. Any help would be greatly appreciated. Thank you.
Published by: blackhole82 on January 20, 2009 09:20Hello
You cannot use the alias column in the query, even where it is set (except in the ORDER BY clause).
You can set the alias in a subquery and then use it in a great query, like this:WITH sub_q AS ( SELECT DISTINCT spriden_pidm,spriden_id id, spriden_last_name||', '||spriden_first_name name, CASE WHEN rcresar_comm_code_01 IN ('268','269','270') THEN rcresar_comm_code_01 WHEN rcresar_comm_code_02 IN ('268','269','270') THEN rcresar_comm_code_02 WHEN rcresar_comm_code_03 IN ('268','269','270') THEN rcresar_comm_code_03 WHEN rcresar_comm_code_04 IN ('268','269','270') THEN rcresar_comm_code_04 WHEN rcresar_comm_code_05 IN ('268','269','270') THEN rcresar_comm_code_05 WHEN rcresar_comm_code_06 IN ('268','269','270') THEN rcresar_comm_code_06 WHEN rcresar_comm_code_07 IN ('268','269','270') THEN rcresar_comm_code_07 WHEN rcresar_comm_code_08 IN ('268','269','270') THEN rcresar_comm_code_08 WHEN rcresar_comm_code_09 IN ('268','269','270') THEN rcresar_comm_code_09 WHEN rcresar_comm_code_10 IN ('268','269','270') THEN rcresar_comm_code_10 END acg_elig_comm_code -- Originally posted with , here (error) FROM spriden, rcresar, rcrapp1 WHERE (rcresar_comm_code_01 IN ('268','269','270') OR rcresar_comm_code_02 IN ('268','269','270') OR rcresar_comm_code_03 IN ('268','269','270') OR rcresar_comm_code_04 IN ('268','269','270') OR rcresar_comm_code_05 IN ('268','269','270') OR rcresar_comm_code_06 IN ('268','269','270') OR rcresar_comm_code_07 IN ('268','269','270') OR rcresar_comm_code_08 IN ('268','269','270') OR rcresar_comm_code_09 IN ('268','269','270') OR rcresar_comm_code_10 IN ('268','269','270')) AND rcresar_aidy_code = &aidy_code AND rcrapp1_aidy_code = rcresar_aidy_code AND rcrapp1_curr_rec_ind = 'Y' AND rcrapp1_seq_no = rcresar_seq_no AND spriden_pidm = rcresar_pidm AND rcrapp1_pidm = rcresar_pidm AND spriden_change_ind IS NULL ) SELECT sub_q.*, CASE WHEN acg_elig_comm_code = '268' THEN 'Rigorous HS course' WHEN acg_elig_comm_code = '269' THEN '2 or more AP or IB' WHEN acg_elig_comm_code = '270' THEN 'ACG possible' END comm_code_description FROM sub_q ORDER BY name
Furthermore, you might think to rearrange your table, so that you do not have 10 columns (rcresar_comm_code_01, rcresar_comm_code_02,...) that essentially do the same thing. The usual way to handle this kind of one-to-many relationship is to have all rcresar_comm_codes in a separate table, one per line, with a pointer to the table where you have them now.
Published by: Frank Kulash, January 20, 2009 11:35
Syntax error has been corrected -
Need help with query SQL Inline views + Group
Hello gurus,
I would really appreciate your time and effort on this application. I have the following data set.
Reference_No---Check_Number---Check_Date---description---Invoice_Number---Invoice_Type---Paid_Amount---Vendor_Number
1234567 11223 - 05/07/2008 -paid for cleaning- 44345563-I-* 20.00 *---19
1234567 11223 - 05/07/2008 - 44345563 -a--10,00---19 ofbad quality adjustment
7654321 11223 - 05/07/2008 - setting the last billing cycle - 23543556 - A - 50.00 - 19
4653456 11223 - 05/07/2008 - paid for cleaning - 35654765 - I - 30, 00-19
Please ignore '-' added for clarity
I'm writing a paid_amount based on Reference_No, Check_Number, Payment_Date, Invoice_Number, aggregate query Invoice_Type, Vendor_Number and display description with Invoice_type 'I' when there are multiple records with the same Reference_No, Check_Number, Payment_Date, Invoice_Type, Invoice_Number, Vendor_Number. When there are no more records I want to display the respective Description.
The query should return the following data set
Reference_No---Check_Number---Check_Date---description---Invoice_Number---Invoice_Type---Paid_Amount---Vendor_Number
1234567 11223 - 05/07/2008 -paid for cleaning- 44345563-I-* 10.00 *---19
7654321 11223 - 05/07/2008 - setting the last billing cycle - 23543556 - A - 50.00 - 19
4653456 11223 - 05/07/2008 - paid for cleaning - 35654765 - I - 30, 00-19
Here's my query. I'm a little lost.
Select b., A.sequence_id, A.check_date, A.check_number, A.invoice_number, A.amount, A.vendor_number
de)
Select sequence_id, check_number, check_date, invoice_number, sum (paid_amount) sum, vendor_number
of the INVOICE
Sequence_id group check_date, check_number, invoice_number, vendor_number
) A, B OF INVOICE
where A.sequence_id = B.sequence_id
Thank you
NickIt seems that this is a duplicate thread - correct me if I am wrong in this case->
Need help with query SQL Inline views + Group
Kind regards.
LOULOU.
-
Help with the Powershell script to collect logs from all domain controllers
I am writing a script to retrieve the last 5 days of application, security and log files from all domain controllers. The script runs, but fire the logs from the local server only. The variable $Computer has all of my DC so it's the fine mark. I guess it's a problem with my line ForEach-Object, but is not error. See the below script.
$log = 'application '.
$date = get-date-format MM-DD-YYYY
$now = get-date
$subtractDays = new-object System.TimeSpan 5,0,0,0,0
$then = $Now.Subtract ($subtractDays)
$Computers = get-ADDomainController-filter *.
ForEach-Object - InputObject $Computers - process {Get-EventLog - LogName $log - after $then - before $now - EntryType error | select EventID, MachineName, Message, Source, TimeGenerated |} ConvertTo-html | {Out-file $env:TEMP\Applicationlog.htm}
Invoke-Expression $env:TEMP\Applicationlog.htmThank you
Rich
Hello
To help with the repost the question script to the script Center Forum
http://social.technet.Microsoft.com/forums/scriptcenter/en-us/home
-
Need help with PL/SQL so and then select
Hello guys, I am new to the PL/SQl programming (only Java experience) and I'm pretty stuck to my task. It would be great if you could help me. I am in programming with Oracle SQL * Plus Version 10.2.0.3.0
Whenever a user logs on to the server a database entry is created with information about the logged-on user. I need to create a PL/SQL command that selects all the information from last month. Unfortunately, the date_stamp column has a certain weird format: 1131210 for December 10, 2013
My idea so far:
DECLARE
v_today NUMBER;
BEGIN
v_today: = TO_NUMBER (TO_CHAR (SYSDATE, 'MM')); -Save the number of the month (e.g.12) in v_today
IF v_today = 01 THEN
SELECT * from audittrl
WHERE the date_stamp between 1131201 AND the 1131231;
ELSIF v_today = 02 THEN
SELECT * from audittrl
WHERE the date_stamp between the 1130131 AND 1130101;
.......
END IF;
END;
/
Error code: "an INTO clause in this SELECT statement.
I do not want to save the result to select a variable, hope you can help me. Thanks in advance.
Hello
6a4d1bcd-c00e-4dac-AB64-9b6bdb1652d1 wrote:
Thanks, I'll try that, if still get caught once, I'll be back. Anway I'm not sure of the solution of Chris227, because I can't test it right now. From my point of view it gives you information the current month (e.g., December) and not the month previous (-online November), or have I missed something. ?
You are right. In addition, it does not for a given year. If you have data from several years in the table, it will select lines for the month of December 2012, 2011, 2010,... but also of 2013.
Here's a way to get around that:
DECLARE
prev_month_start PLS_INTEGER: = TO_NUMBER (TO_CHAR (ADD_MONTHS (SYSDATE-1)
, "YYMM"1' "01"
)
);
this_month_start PLS_INTEGER: = TO_NUMBER (TO_CHAR (SYSDATE
, "YYMM"1' "01"
)
);
BEGIN
FOR (IN) rec
SELECT *.
Of audittrl
WHERE the date_stamp > = prev_month_start
AND date_stamp< > >
ORDER BY user_id, date_stamp - or other)
LOOP
dbms_output.put_line (rec.date_stamp);
dbms_output.put_line (rec.event);
dbms_output.put_line (rec.user_id)
dbms_output.put_line (rec.host_name);
END LOOP;
END;This should also be more effective, because it will allow the optimizer to use an index on date_stamp. Even if there is no index, it will be more effective because it avoids calling any function (for example, SUBSTR) on each line of the table.
You needn't PL/SQL to get these results. Just use SQL, you might say:
SELECT event, host_name, user_id and date_stamp
Of audittrl
WHERE the date_stamp > = TO_NUMBER (TO_CHAR (ADD_MONTHS (SYSDATE-1)
, "YYMM"1' "01"
)
)
AND date_stamp< to_number="" (="" to_char="" (="" sysdate="" to_number="" (="" to_char="" (=""> >
, "YYMM"1' "01"
)
)ORDER BY user_id, date_stamp - or other
;
Your front end will provide column headers and touch the data so that the columns line up. It can also set the output to a file. (For example, if your front-end is SQL * Plus, you can use the command of the COIL.)
I guess date_stamp is a NUMBER. If it is a string, the solutions above can be simplified a bit.
This problem (and many other problems) would be so much simpler if date_stamp was a DATE column. Using numbers or strings to store the date information is simply asking for trouble.
-
Need help with PL/SQL query complex
I need help with a query that need access to data from 3 tables. That's what I did
I created 3 tables
CREATE TABLE post_table
(
post_id varchar (20),
datepost DATE,
KEY (post_id) elementary SCHOOL
) ;
CREATE TABLE topic
(
TOPIC_ID varchar (20),
name varchar (20),
PRIMARY KEY (topic_id)
);
CREATE TABLE blogpost_table
(
TOPIC_ID varchar (20),
post_id varchar (20),
PRIMARY KEY (topic_id, post_id);
FOREIGN KEY (topic_id) REFERENCES topic (topic_id) ON DELETE CASCADE,
FOREIGN KEY (post_id) REFERENCES post_table (post_id) ON DELETE CASCADE
);
Now, I inserted a few values in these tables as
INSERT INTO post_table VALUES ('p1', to_date ('2009-09-14 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO post_table VALUES ('p2', to_date ('2009-07-18 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO post_table VALUES ('p3', to_date ('2009-07-11 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO post_table VALUES ('p4', to_date ('2009-03-11 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO post_table VALUES ('p5', to_date ('2009-07-13 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO post_table VALUES ('p6', to_date ('2009-06-12 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO post_table VALUES ('p7', to_date ('2009-07-11 18:00 "," MM/DD/YYYY mi:ss'));))
INSERT INTO VALUES subject ("t1", "baseball");
INSERT INTO category VALUES ('t2', 'football');
INSERT INTO blogpost_table VALUES ("t1", "p1");
INSERT INTO blogpost_table VALUES ('t1', 'p3');
INSERT INTO blogpost_table VALUES ("t1", "p4");
INSERT INTO blogpost_table VALUES ('t1', 'p5');
INSERT INTO blogpost_table VALUES ('t2', 'p2');
INSERT INTO blogpost_table VALUES ('t2', 'p6');
INSERT INTO blogpost_table VALUES ("t2", "p7");
I'm launching SQL queries on the table in this topic.
I want to write a SQL query that returns me the name of a topic (s) and the number of blog_post (s) associated with the topic in descending order of the number of blog posts created in July.
Can someone please help me to write this query?
Thank you
Published by: user11994430 on October 9, 2009 07:24Thanks for the test of the configuration!
SQL>SELECT t.NAME, COUNT(*) 2 FROM topic t, blogpost_table b, post_table p 3 WHERE b.topic_id = t.topic_id 4 AND p.post_id = b.post_id 5 AND p.datepost >= DATE '2009-07-01' 6 AND p.datepost < DATE '2009-08-01' 7 GROUP BY t.NAME 8 ORDER BY COUNT(*) desc; NAME COUNT(*) -------------------- ---------- baseball 2 soccer 2
HTH, Urs
-
Help with oracle sql to get all possible combinations in a table.
Hello guys I have a small predicatement which has me a little confused. I have a table similar to the following. (It is a sample of my real of the table. I use this to explain the original table containing sensitive data).
CREATE TABLE TEST01( TUID VARCHAR2(50), FUND VARCHAR2(50), ORG VARCHAR2(50));
Insert into TEST01 (TUID,FUND,ORG) values ('9102416AB','1XXXXX','6XXXXX'); Insert into TEST01 (TUID,FUND,ORG) values ('9102416CC','100000','67130'); Insert into TEST01 (TUID,FUND,ORG) values ('955542224','1500XX','67150'); Insert into TEST01 (TUID,FUND,ORG) values ('915522211','1000XX','67XXX'); Insert into TEST01 (TUID,FUND,ORG) values ('566653456','xxxxxx','xxxxx');
The 'X' is wildcard character elements * (I inherit it and I can not change the table format) * I would like to make a query as follows"TUID" "FUND" "ORG" "9102416AB" "1XXXXX" "6XXXXX" "9102416CC" "100000" "67130" "955542224" "1500XX" "67150" "915522211" "1000XX" "67XXX" "566653456" "xxxxxx" "xxxxx"
However I like to do is to retrieve all the records that have have these segments in them including ' xselect tuid from test01 where fund= '100000' and org= '67130'
in other words the output expected here would be
I started to write a massive sql statement that would have the 12 as the instruction inside, because I must compare the org and finance every possible way."TUID" "FUND" "ORG" "9102416AB" "1XXXXX" "6XXXXX" "9102416CC" "100000" "67130" "915522211" "1000XX" "67XXX" "566653456" "xxxxxx" "xxxxx"
This is where im headed. but im wondering if there is a better way.
can someone give me a hand to come with this sql statement...select * from test02 where fund = '100000' and org = '67130' or fund like '1%' and org like '6%' or fund like '1%' and org like '67%' or fund like '1%' and org like '671%' or fund like '1%' and org like '6713%' or fund like '1%' and org like '67130' or fund like '10%' and org like '6%'...etc /*seems like there should be a better way..*/
mlov83 wrote:
If I run the presentselect tuid,fund, org from test01 where '100000' like translate(fund, 'xX','%%') and '67130' like translate(org, 'xX','%%');
That's what I
"TUID" "FUND" "ORG" "9102416AB" "1XXXXX" "6XXXXX" "9102416CC" "100000" "67130" "915522211" "1000XX" "67XXX" "566653456" "xxxxxx" "xxxxx" "9148859fff" "1XXXXXX" "X6XXX"
the last item should be excluded. The second digit in "org" is a "7".
Fund is bad, too. Looking for 6 characters ("100000"), but the funds on this line is 7 characters ("1XXXXXX").
and it's always get picked up.
That's why you should use the Joker _ instead of %
select tuid, fund, org from test01 where '100000' like translate (fund, 'xX', '__') and '67130' like translate (org, 'xX', '__') ;
It is difficult to see, but in two calls to TRANSLATE, the 3rd argument is a string 2 ' _.
-
IP number looking for PSI - need help with a sql solution better and faster
Hello
I have a table (one) with more 1 000 000 IP addresses and numbers (the digital equivalent of the IP address)
I have a second table (b) which contains a mapping between the ranges of the ISP and IP. The table looks like this and more contains 150 000 entries:
BEGIN_IP_RANGE END_IP_RANGE ISP_NAME
-------------------------- ---------------------- --------------
600000000 700000000 ISP_X
800000000 900000000 ISP_Y
I'm creating a third table (c) which connects (a) IP numbers to identify the ISP from (B). The query looks like this:
CREATE TABLE c
AS
Select a.IP_ADDRESS
b.ISP_NAME
IP_NUMBERS a, ISP_LOOKUP b lkp
where a.IP_NUMBER between b.BEGIN_IP_RANGE and b.END_IP_RANGE
;
There is no key join between the 2 tables and so I use TO search for the access provider. The performace of it's terrible and table (c) takes several hours to create.
Does anyone have any thoughts/ideas/suggestions on how this research can be achieved by using a solution better and faster?
Thank you very much
Shah
The performace of it's terrible and table (c) takes several hours to create.
Hours what do you say?
See if the following can help.
Cardinalities are similar to yours. The ETG takes 7sec. :
SQL> create table ip_numbers (ip_address, ip_number) as 2 select cast(to_char(level,'fm099G999G999G999', 'nls_numeric_characters=,.') as varchar2(15)) 3 , level 4 from dual 5 connect by level <= 1000000 ; Table created. SQL> select * from ip_numbers where rownum <= 10; IP_ADDRESS IP_NUMBER --------------- ---------- 000.000.000.001 1 000.000.000.002 2 000.000.000.003 3 000.000.000.004 4 000.000.000.005 5 000.000.000.006 6 000.000.000.007 7 000.000.000.008 8 000.000.000.009 9 000.000.000.010 10 10 rows selected. SQL> SQL> create table isp_lookup (begin_ip_range, end_ip_range, isp_name) as 2 select 1 + (level-1)*5 3 , level*5 4 , cast('ISP_'||to_char(level,'fm099999') as varchar2(10)) 5 from dual 6 connect by level <= 200000 ; Table created. SQL> select * from isp_lookup where rownum <= 10; BEGIN_IP_RANGE END_IP_RANGE ISP_NAME -------------- ------------ ---------- 1 5 ISP_000001 6 10 ISP_000002 11 15 ISP_000003 16 20 ISP_000004 21 25 ISP_000005 26 30 ISP_000006 31 35 ISP_000007 36 40 ISP_000008 41 45 ISP_000009 46 50 ISP_000010 10 rows selected. SQL> create index ip_address_number_ix on ip_numbers (ip_number); Index created. SQL> set timing on SQL> SQL> create table ip_mappings as 2 select /*+ use_nl(a b) */ 3 a.ip_address 4 , b.isp_name 5 from isp_lookup b 6 join ip_numbers a on a.ip_number between b.begin_ip_range 7 and b.end_ip_range 8 ; Table created. Elapsed: 00:00:06.94 SQL> select count(*) from ip_mappings; COUNT(*) ---------- 1000000 Elapsed: 00:00:01.22
-
Need help with understanding PowerCli scripting by LucD
Hello
I'll give you the standard statement that I am a noob powercli and don't really know what I'm doing here. Here's a script that works because it runs without error and gives a report but I need help to understand this under his weight.
Connect-VIServer '< our vcenter >' - user < user > admin-password < admin-user-pwd >
$allvms = @)
$vms = get - Vm | where {$_.} PowerState - eq "Receptor"}
$start = (get-Date). AddDays(-1)
$metrics = "mem.usage.average".
$stats = get-Stat-entity $vms - start $start - Stat $metrics
$stats | Group-object - property {$_.} Timestamp.Day}, {$_.} @entity.name} | %{
$vmstat = "" | Select the day, MemAlloc, MemMin, MemMax, MemAvg, VmName
$vmstat. VmName = $_. Values [1]
$vmstat. Day = $_. Group [0]. Timestamp.Date
$mem = $_. Group | where {$_.} MetricId - eq "mem.usage.average"} | Measure-object-property value - average - Maximum - Minimum
$vmstat. MemMax = [int] $mem. Maximum ##dfsdf
$vmstat. MemAvg = [int] $mem. Average
$vmstat. MemMin = [int] $mem. Minimum
$vmstat. MemAlloc = $_. Group [0]. Entity.MemoryMB
$allvms += $vmstat
}
$allvms |
Export-Csv "c:\ < folder > \ <>.csv file Destination"-noTypeInformation
It connects to our server vcenter server and offers two days of data. Today and yesterday, all with a timestamp of 0:00. See below for an example of a virtual machine.
VmName Day MemAlloc MemMax MemAvg MemMin < name VM1 > 07/05/2016 0:00 4096 18 18 18 < name VM1 > 06/05/2016 0:00 4096 36 12 8
The MemMax, the MemAvg and the MemMin are for this day? Just the max of this period of sampling time 0:00?
What I'm looking for, it is to find that the use of the maximum memory of virtual machines are for the whole day. So I hope that I can remove memory of VMs that do not use it. I was listed on the change $start = (Get-Date). The value of AddDays(-1) to $start = (Get-Date). AddDays(-30) and see what things alike. I want to be sure however that the value for MemMax is the highest value for a period of 24 hours. That is to say for the 07/05/2016 the given virtual machine never used a maximum of 18% of his memory attributed the 06/05/2016 the maximum amount of memory used was 36%, and so on that I extend on the date range.
Kind regards
Michael
It then becomes a rather simple Get-Stat script.
$vms = get - Vm | where {$_.} PowerState - eq "Receptor"}
$start = (get-Date). AddDays(-1)
$metrics = "mem.usage.average".
Get-Stat - entity $vms - start $start - Stat $metrics |
Select Timestamp,@{N='VM'; E={$_. @entity.name}}, Value |
Tri-objet-VM property |
Export-Csv "c:\
------ .csv '-noTypeInformation -
Need help with Oracle SQL merge records according to date and term dates
Hi all
I need help to find this little challenge.
I have groups and flags and effective dashboards and dates of term against these indicators according to the following example:
GroupName Flag_A Flag_B Eff_date Term_date Group_A THERE THERE 20110101 99991231 Group_A N N 20100101 20101231 Group_A N N 20090101 20091231 Group_A N N 20060101 20081231 Group_A N THERE 20040101 20051231 Group_A THERE THERE 20030101 20031231 Group_B N THERE 20040101 99991231 Group_B N THERE 20030101 20031231 As you can see, group_A had the same combination of (N, N) flag for three successive periods. I want to merge all the time periods with the same indicators in one. Where entry into force will be the most early (underlined) time period and end date will be later (underlined)
So the final result should look like this:
GroupName Flag_A Flag_B Eff_date Term_date Group_A THERE THERE 20110101 99991231 Group_A N N 20060101 20101231 Group_A N THERE 20040101 20051231 Group_A THERE THERE 20030101 20031231 Group_B N THERE 20030101 99991231 Thanks for your help
Here's the DDL script
drop table TMP_group_test;
create table TMP_group_test (groupname varchar2 (8))
, flag_a varchar2 (1)
, flag_b varchar2 (1)
, eff_date varchar2 (8)
, term_date varchar2 (8)
);
insert into TMP_group_test values ('Group_A', 'Y', 'Y', ' 20110101 ', ' 99991231');
insert into TMP_group_test values ('Group_A', 'n', ' n ', ' 20100101 ', ' 20101231');
insert into TMP_group_test values ('Group_A', 'n', ' n ', ' 20090101 ', ' 20091231');
insert into TMP_group_test values ('Group_A', 'n', ' n ', ' 20060101 ', ' 20081231');
insert into TMP_group_test values ('Group_A', 'n', 'Y', ' 20040101 ', ' 20051231');
insert into TMP_group_test values ('Group_A', 'Y', 'Y', ' 20030101 ', ' 20031231');
insert into TMP_group_test values ('Group_B', 'n', 'Y', ' 20040101 ', ' 99991231');
insert into TMP_group_test values ('Group_B', 'n', 'Y', ' 20030101 ', ' 20031231');
commit;
Post edited by: user13040446
It is the closest, I went to the solution
I create two rows;
Rnk1: partition by group name, order of eff_date / / desc: this grade will sort the records of the most recent and handed to zero for each group\
Rnk2: (dense) partition by group name, flag_A, flagb: this grade for each combination of group\flag gives a number so that they are classified as "families".
Then I use the function analytic min
Min (eff_date) more (partition of GroupName, rnk2): the idea is that, for each Member of the same family, the new date is the min of the family (and the max for the date of the term), at the end I just need separate so that the duplicates are gone
Now the problem. As you can see from the query below, records of 1 and 6 (as identified by rownum) are identified in the same family, because they have the same combination of flag, but they are not successive, so everyone must keep its own date of entry into force.
If only I can make the distinction between these two that would solve my problem
Query:
Select rowNum,GroupName, flag_a, flag_b, eff_date, term_date, rnk1, rnk2
, min (eff_date) more than (partition by GroupName rnk2( ) min_eff
Of
(
Select rowNum,
GroupName , flag_a , flag_b , eff_date , term_date
rank() more than (partition by GroupName stopped by eff_date desc) rnk1
DENSE_RANK() more than (partition by GroupName order by flag_A flag_B ( ) rnk2
de dsreports . tmp_group_test
) order by rowNum
Hello
user13040446 wrote:
Hi KSI.
Thanks for your comments, you were able to distinguish between these lines highlight, but lost lines 2,3,4 which are supposed to have the same date min = 20060101.
Please see the table wanted to see the final result I want to reach
Thanks again
This first answer is basically correct, but in the main query, you want to use the function MIN, not the analytical function aggregation and GROUP BY columns with common values, like this:
WITH got_output_group AS
(
SELECT GroupName, flag_a, flag_b, eff_date, term_date
ROW_NUMBER () OVER (PARTITION BY GroupName
ORDER BY eff_date
)
-ROW_NUMBER () OVER (PARTITION BY GroupName, flag_a, flag_b)
ORDER BY eff_date
) AS output_group
OF tmp_group_test
)
SELECT GroupName, flag_a, flag_b
MIN (eff_date) AS eff_date
MAX (term_date) AS term_date
OF got_output_group
GROUP BY GroupName, flag_a, flag_b
output_group
ORDER BY GroupName
eff_date DESC
;
The result I get is
GROUP_NA F F EFF_DATE TERM_DAT
-------- - - -------- --------
Group_A Y 20110101 99991231 Y
N Group_A 20101231 20060101 N
Group_A N 20051231 20040101 Y
Group_A Y Y 20031231-20030101
Group_B N Y 99991231 20030101
which is what you asked for.
-
Help with PL/SQL Performance Tuning
Hi all
I have a PL/SQL procedure, it works very well. No error and no bugs. However its still holding at the end I use the concatenation operator (|), and I know that its expensive. How to improve the performance of the procedure?
Here is the code
create or replace PROCEDURE POST_ADDRESS_CLEANSE AS CURSOR C1 IS SELECT Z.ROW_ID, Z.NAME FROM STGDATA.ACCOUNT_SOURCE Z; CURSOR C2 IS SELECT DISTINCT CLEANSED_NAME || CLEANSED_STREET_ADDRESS || CLEANSED_STREET_ADDRESS_2 || CLEANSED_CITY || CLEANSED_STATE || CLEANSED_POSTAL_CODE AS FULLRECORD FROM STGDATA.ACCOUNT_SOURCE_CLEANSED; V_ROWID Number := 1; V_FLAG VARCHAR2(30); TEMP_ROW_ID VARCHAR2(10) := NULL; BEGIN -- This loop will update CLEANSED_NAME column in ACCOUNT_SOURCE_CLEANSED table. FOR X IN C1 LOOP TEMP_ROW_ID := TO_CHAR(X.ROW_ID); UPDATE STGDATA.ACCOUNT_SOURCE_CLEANSED A SET A.CLEANSED_NAME = X.NAME WHERE A.ROW_ID = TEMP_ROW_ID; COMMIT; END LOOP; -- This loop will update columns EM_PRIMARY_FLAG, EM_GROUP_ID in ACCOUNT_SOURCE_CLEANSED table FOR Y IN C2 LOOP UPDATE STGDATA.ACCOUNT_SOURCE_CLEANSED SET EM_GROUP_ID = V_ROWID WHERE CLEANSED_NAME || CLEANSED_STREET_ADDRESS || CLEANSED_STREET_ADDRESS_2 || CLEANSED_CITY || CLEANSED_STATE || CLEANSED_POSTAL_CODE = Y.FULLRECORD; UPDATE STGDATA.ACCOUNT_SOURCE_CLEANSED SET EM_PRIMARY_FLAG = 'Y' WHERE CLEANSED_NAME || CLEANSED_STREET_ADDRESS || CLEANSED_STREET_ADDRESS_2 || CLEANSED_CITY || CLEANSED_STATE || CLEANSED_POSTAL_CODE = Y.FULLRECORD AND ROWNUM = 1; V_ROWID := V_ROWID + 1; COMMIT; END LOOP; UPDATE STGDATA.ACCOUNT_SOURCE_CLEANSED SET EM_PRIMARY_FLAG = 'N' WHERE EM_PRIMARY_FLAG IS NULL; COMMIT; --dbms_output.put_line('V_ROW:'||V_ROWID); --dbms_output.put_line('CLEANSED_NAME:'||Y.FULLRECORD); END POST_ADDRESS_CLEANSE;
Thanks in advance.
Post edited by: Rooney - added code using the syntax highlight
Thanks for everyone entered.
I was able to solve the problem. My solution using the old code with the |, I was able to create an index on the following attributes:
CLEANSED_NAME | CLEANSED_STREET_ADDRESS | CLEANSED_STREET_ADDRESS_2 | CLEANSED_CITY | CLEANSED_STATE | CLEANSED_POSTAL_CODE
I never knew that you can create an index on the concatenated attributes sets. Doing this, I was able to update all of my files and improve performance. All records ran in 80 seconds.
Thanks again for the help.
-
Help with PL/SQL procedure...
Hello world
I'm new to PL/SQL and still to learn, so please bare with me. Below, I've pasted my code for your consideration and assistance. Everything seems to work as expected, however, I have a problem with a particular indicated section below...
-Updated amount of film to add the amount
UPDATE mm_movie
SET movie_qty = v_movie_qty + 1
WHERE movie_id = v_movie_id;
When compiling this procedure, I don't get any errors and it is compiled successfully, but for some reason the amount of film is not added. What I'm missing here? Any help would be really appreciated.
Here is the full procedure
-Start of the procedure
create or replace PROCEDURE MOVIE_RETURN_SP
-Parameter declaration
(p_rent_id IN mm_rental.rental_id%TYPE)
IS
-Variables
v_title NUMBER;
v_count_rentid NUMBER;
v_movie_id NUMBER;
v_checkin_date DATE;
v_qty NUMBER;
v_movie_qty NUMBER;
ex_norent_record EXCEPTION;
ex_already_returned EXCEPTION;
BEGIN
Select count (rental_id)
in v_count_rentid
of mm_rental
where rental_id = p_rent_id;
IF (v_count_rentid = 0) THEN
RAISE ex_norent_record;
END IF;
-id check in date based on the record of rental and film
SELECT movie_id, checkin_date
IN v_movie_id, v_checkin_date
OF mm_rental
WHERE rental_id = p_rent_id;
-Make sure that the film was not already returned
IF v_checkin_date IS NOT NULL THEN
RAISE ex_already_returned;
END IF;
Select movie_qty
IN v_movie_qty
of mm_movie
where movie_id = v_movie_id;
-Update folder location to register CHECKIN_DATE
UPDATE mm_rental
SET checkin_date = SYSDATE
WHERE rental_id = p_rent_id;
-Updated amount of film to add the amount
UPDATE mm_movie
SET movie_qty = v_movie_qty + 1
WHERE movie_id = v_movie_id;
EXCEPTION
WHEN ex_norent_record THEN
dbms_output.put_line (' rental ID ' | p_rent_id |) "does not exist!");
WHEN ex_already_returned THEN
dbms_output.put_line (' rental ' | p_rent_id |) "already back!");
END;
/
-End of the procedure
Hello
I wanted to tell you the data type mismatch, just to run this code, let me know where you get the error, but remember that the values are not null.
CREATE OR REPLACE PROCEDURE movie_return_sp
-Parameter declaration
(
p_rent_id IN mm_rental.rental_id%TYPE
)
IS
-Variables
v_title NUMBER;
v_count_rentid mm_rental.rental_id%TYPE;
v_movie_id mm_rental.movie_id%TYPE;
v_checkin_date mm_rental.checkin_date%TYPE;
v_qty NUMBER;
v_movie_qty mm_movie.movie_qty%TYPE;
ex_norent_record EXCEPTION;
ex_already_returned EXCEPTION;
BEGIN
BEGIN
SELECT COUNT (rental_id)
IN v_count_rentid
OF mm_rental
WHERE rental_id = p_rent_id;
EXCEPTION
WHILE OTHERS
THEN
Dbms_output.put_line ('error_in_first_block');
END;IF (v_count_rentid = 0)
THEN
RAISE ex_norent_record;
END IF;BEGIN
-id check in date based on the record of rental and film
SELECT movie_id, checkin_date
IN v_movie_id, v_checkin_date
OF mm_rental
WHERE rental_id = p_rent_id;
EXCEPTION
WHILE OTHERS
THEN
Dbms_output.put_line ('error_in_second_block');
END;-Make sure that the film was not already returned
IF v_checkin_date IS NOT NULL
THEN
RAISE ex_already_returned;
END IF;BEGIN
SELECT movie_qty
IN v_movie_qty
OF mm_movie
WHERE movie_id = v_movie_id;
EXCEPTION
WHILE OTHERS
THEN
Dbms_output.put_line ('error_in_third_block');
END;BEGIN
-Update folder location to register CHECKIN_DATE
UPDATE mm_rental
SET checkin_date = SYSDATE
WHERE rental_id = p_rent_id;
EXCEPTION
WHILE OTHERS
THEN
Dbms_output.put_line ('error_during_update1');
END;BEGIN
-Updated amount of film to add the amount
UPDATE mm_movie
SET movie_qty = v_movie_qty + 1
WHERE movie_id = v_movie_id;
EXCEPTION
WHILE OTHERS
THEN
Dbms_output.put_line ('error_during_update2');
END;
EXCEPTION
WHEN ex_norent_record
THEN
Dbms_output.put_line ('Rental ID' | p_rent_id |) "does not exist!");
WHEN ex_already_returned
THEN
Dbms_output.put_line ('Rent' | p_rent_id |) "already back!");
WHILE OTHERS
THEN
Dbms_output.put_line ('unexpected error');
END;
/ -
I am looking for 2 very simple scripts, we're for a specific cluster 1, I want to list all the VMS that have 4 GB of memory or more.
Then a 2nd script for a specific cluster1, want to list VM which do not have the VM tools installed or are out of date and select the name, the tool vmware status and memory.
Can someone help please
Here is a line that I tried on a single host... and must work if you connect on a VC as well... people it will list all virtual machines with more than 4 GB of memory:
Get - VM | Where-Object {$_.} MemoryMB - gt 4096}
If you want just the name and memory, then:
Get - VM | Where-Object {$_.} MemoryMB - gt 4096} | Select Name, MemoryMB
For the other for the VMtools...
Get-VM | Get-View | Select-Object @{N="Name";E={$_.Name}},@{Name="ToolsStatus";E={$_.Guest.ToolsStatus}}
Concerning
Maybe you are looking for
-
USB storage file change password
Records of advanced storage available-network settings Netgear engineering-advanced-WPS Wizard-USB Connected to a USB 2.0 flash drive to the router and networking (readyshare) is fine, my question seeks to define a password for read & write access, a
-
HP 7610: lines to scan hp 7610
I get a line when I scan using the ADF for my HP 7610. I checked where it appears and it does not appear until a roll it seems there is something in there, causing somewhere this line. I've included a picture where the line is displayed. Any help in
-
Clock accuracy for NI 446 x specifications
I need the specification of the standard of accuracy of sampling rate (internal clock) for the series X 446. I need to know how the tilt of the clock can also be introduced perferrably with temperature information. Where can I find this information?
-
System Restore can remove a Virus.
I don't think I have a virus, but I was just curious. Because Microsoft System Restore restores the files and settings, can it remove a virus?
-
How Notification difficulty bar lagy performance?
Hiiiiii please READ AND RESPOND PLEASE! I have try all the Roma as Cm9, team kang, etc... in these Roma bar notification to the top and at the bottom is very smooth, but problem is camera... Then This is why I m does not help these roms... now I m on