Meassge sending termwise [message #659714] |
Fri, 27 January 2017 21:02 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
shahzad-ul-hasan
Messages: 643 Registered: August 2002
|
Senior Member |
|
|
Respected Sir,
i want to send sms to parents mobile termwise. but when use the following code the parents received message separate separate subject. For example if we have 4 subject the parents received message 4 time not 1 time.
declare
a number; -- Student ID
b varchar2(300); --Student Name
c varchar2(30); --Mobile
CURSOR cc IS
select distinct stuid,,name,mobile from student where status='PRESENT';
BEGIN
open cc;
LOOP
fetch Cc into A,B,C;
insert into msgout (id,msgto,msg)
values
(a,c,'Marks Sheet of student '|| b || 'is as under: '|| :SNO ||':'|| :obtmarks ||' / '|| tmarks);
EXIT when Cc%NOTFOUND;
next_record;
END LOOP;
Close c;
end;
Required OutPut Is:
Marks Sheet of ABC is as under:
English: 30/50
urdu: 39/50
Math: 3/50
please view the attached test case.
[Updated on: Fri, 27 January 2017 21:03] Report message to a moderator
|
|
|
|
|
|
|
|
|
Re: Meassge sending termwise [message #659726 is a reply to message #659725] |
Sat, 28 January 2017 07:35 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
shahzad-ul-hasan
Messages: 643 Registered: August 2002
|
Senior Member |
|
|
Quote:>>
>> Respected Parents! Marks Sheet of Amina Fardous of class NineS for the DECEMBER TEST 2016 is as under. Math:37 / 50 His/Her Perct. is 74.
>> Respected Parents! Marks Sheet of Amina Fardous of class NineS for the DECEMBER TEST 2016 is as under. Bio/Comp:37 / 50 His/Her Perct. is 74
>> Respected Parents! Marks Sheet of Amina Fardous of class NineS for the DECEMBER TEST 2016 is as under. Phy:27 / 50 His/Her Perct. is 54
this is i got mesage from this query;
DECLARE
B VARCHAR2(30);
A VARCHAR2(30);
C VARCHAR2(500);
D VARCHAR2(33);
E VARCHAR2(50);
F VARCHAR2(30);
CURSOR CC IS
SELECT DISTINCT S.STUID,F.MOBILE,S.NAME,S.CLASS,TS.TSUBJ,T.EXAMC
FROM STUDENT S,FAMILY F,TSUBJ TS,TEST T
WHERE S.CLASS=:TEST.CLASS AND S.SECTION=:TEST.SEC AND S.STATUS='PRESENT'
AND S.STUID IN (SELECT DISTINCT STUID FROM STUDENT
WHERE STATUS='PRESENT') AND F.FAM_ID=S.FAM_ID AND TS.CNAME=:CLASS;
BEGIN
OPEN CC;
LOOP
FETCH CC INTO A,B,C,D,E,F;
INSERT INTO MSGOUT (ID,MSGTO,MSG)
VALUES
(A,'+92'||B,'>> Respected Parents! Marks Sheet of '|| C || ' of class ' || d || ' for the '|| F || ' is as under. '|| E ||':'
|| round(:TEST1.OBTMARKS,2) || ' / ' || :totmarks || ' His/Her Perct. is '|| :perct .);
-- NEXT_RECORD;
EXIT WHEN CC%NOTFOUND;
END LOOP;
COMMIT;
CLOSE CC;
END;
Actual Result required.
Respected Parents! Marks Sheet of Amina Fardous of class NineS for the DECEMBER TEST 2016 is as under.
Math: 37/50
Bio/Comp: 37/50
Phy: 27/50
His/Her Perct. is 74.
[Updated on: Sat, 28 January 2017 07:42] Report message to a moderator
|
|
|
|
|
Re: Meassge sending termwise [message #659739 is a reply to message #659738] |
Sat, 28 January 2017 13:59 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
data:image/s3,"s3://crabby-images/0b8c0/0b8c05342dc68f6b54984ee971b9895d5e25a9ae" alt="" |
Littlefoot
Messages: 21823 Registered: June 2005 Location: Croatia, Europe
|
Senior Member Account Moderator |
|
|
First, the obvious facts.
This:Respected Parents! Marks Sheet of Amina Fardous of class NineS for the DECEMBER TEST 2016 is as under. should be inserted only once, before the loop.
This:Math: 37/50
Bio/Comp: 37/50
Phy: 27/50 should be inserted within the loop.
This:should be inserted only once, after the loop.
In order to correctly select inserted values from a table, you'll need additional identifier(s), such as ordinal number of the inserted row (so that you could use ORDER BY).
Finally, I'd suggest you to switch to cursor FOR loop; it is easier to handle. If you insist on current solution type, consider naming variables in a meaningful manner (instead of calling variables A, B, C, ...).
|
|
|
Re: Meassge sending termwise [message #659740 is a reply to message #659739] |
Sat, 28 January 2017 21:33 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
shahzad-ul-hasan
Messages: 643 Registered: August 2002
|
Senior Member |
|
|
PLEASE VIEW THE ATTACHED FILE.
STUID NAME CLASS SECTION MAX(T.EXAMC) SUBJECT TOTMARKS OBTMARKS
560 Sandal NineA A DECEMBER TEST 2016 Eng 50 10
124 Seemab Kanwal NineA A DECEMBER TEST 2016 Isl.O 50 43
140 Aiman Jaleel NineA A DECEMBER TEST 2016 Isl.O 50 0
560 Sandal NineA A DECEMBER TEST 2016 Isl.O 50 44
551 Maryam Maqbool NineA A DECEMBER TEST 2016 Edu 50 37
134 Faiza Iqbal NineA A DECEMBER TEST 2016 G.Sci 50 17
140 Aiman Jaleel NineA A DECEMBER TEST 2016 G.Sci 50 34
560 Sandal NineA A DECEMBER TEST 2016 G.Sci 50 25
8 Husnaina Yousaf NineA A DECEMBER TEST 2016 Math 50 15
124 Seemab Kanwal NineA A DECEMBER TEST 2016 Math 50 25
124 Seemab Kanwal NineA A DECEMBER TEST 2016 Edu 50 41
124 Seemab Kanwal NineA A DECEMBER TEST 2016 G.Sci 50 48
544 Sana Munir NineA A DECEMBER TEST 2016 Math 50 18
560 Sandal NineA A DECEMBER TEST 2016 Math 50 23
8 Husnaina Yousaf NineA A DECEMBER TEST 2016 Edu 50 20
497 Ayesha Noreen NineA A DECEMBER TEST 2016 Edu 50 37
544 Sana Munir NineA A DECEMBER TEST 2016 Eng 50 31
-
Attachment: 1.png
(Size: 9.74KB, Downloaded 2497 times)
[Updated on: Sun, 29 January 2017 01:53] Report message to a moderator
|
|
|
|
Re: Meassge sending termwise [message #659892 is a reply to message #659745] |
Thu, 02 February 2017 07:35 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
shahzad-ul-hasan
Messages: 643 Registered: August 2002
|
Senior Member |
|
|
please advised i have created a view and use this following query to build form of master detail using self join. CREATE OR REPLACE FORCE VIEW W
(
STUID, NAME, CLASS, SECTION, T, SUBJECT, TOTMARKS, MOBILE, OBTMARKS
)
AS
SELECT DISTINCT S.STUID,S.NAME,S.CLASS,S.SECTION,MAX(T.EXAMC) as t,
T.SUBJECT,T.TOTMARKS,F.MOBILE,
TEST1.OBTMARKS
FROM STUDENT S,TEST T,TEST1,FAMILY F
WHERE T.TID=TEST1.TID
AND T.TDATE=TEST1.TDATE
AND TEST1.TSTUID=S.STUID
AND F.FAM_ID=S.FAM_ID
AND S.STUID=TEST1.TSTUID
AND T.CLASS=S.CLASS
AND T.SECTION=S.SECTION
AND STATUS='PRESENT'
AND S.CLASS='NineA'
AND S.SECTION='A'
AND T.EXAMC='DECEMBER TEST 2016'
GROUP BY S.CLASS,S.STUID,S.NAME,S.CLASS,S.SECTION,T.SUBJECT,T.TOTMARKS,
TEST1.OBTMARKS,F.MOBILE
/
or this can be done by nested loops. please help me to build nested loop.
[Updated on: Thu, 02 February 2017 08:05] Report message to a moderator
|
|
|
Re: Meassge sending termwise [message #659904 is a reply to message #659714] |
Thu, 02 February 2017 13:51 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
joy_division
Messages: 4963 Registered: February 2005 Location: East Coast USA
|
Senior Member |
|
|
shahzad-ul-hasan wrote on Fri, 27 January 2017 22:02Respected Sir,
Blah blah blah. I have taken a look at many of your posts. They are all gibberish. You have not once conveyed a coherent question, or even a response.
|
|
|
Re: Meassge sending termwise [message #660120 is a reply to message #659904] |
Thu, 09 February 2017 04:07 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
shahzad-ul-hasan
Messages: 643 Registered: August 2002
|
Senior Member |
|
|
Solved :
select st.stuid,
'Respected Parents! Marks Sheet of ' || st.name ||
' of class NineS for the DECEMBER TEST 2016 is as under.' ||
chr(10) || listagg( obtmarks || '/' || tmarks, chr(10)) within group (order by tmarks) sms
from student st
join test1 t1
on st.stuid = t1.tstuid
join test t
on t.sno = st.stuid
group by st.stuid, st.name;
STUID SMS
1 Respected Parents! Marks Sheet of ABC of class NineS for the DECEMBER TEST 2016 is as under.
30/50
39/50
2 Respected Parents! Marks Sheet of A of class NineS for the DECEMBER TEST 2016 is as under.
16.7/50
16.7/50
Thanks for help
|
|
|
|
|
|