Tilted Forum Project Discussion Community  

Go Back   Tilted Forum Project Discussion Community > Interests > Tilted Technology


 
 
LinkBack Thread Tools
Old 10-23-2006, 06:38 AM   #1 (permalink)
Crazy
 
PL/SQL, SQL

If anyone is bored, please give me thoughts:
Imagine yourself as a graphic designer, in your last semester of college, and for some reason your degree requires you to take this last C-S course. You know nothing about programming, or programming languages. Go.

---

1) Create a database with two tables: Employee and Division. The employee table should contain a unique employee ID, employee name, and manager ID. Manager ID in row X is the ID of the employee who is the direct manager of the employee in row X. The division table should contain a unique division name, a division location, and a manager ID. The manage ID is the employee ID of the employee who is the direct manager of the division. Write create table statements for the database and insert sample data.


2) Create a PL/SQL procedure that is passed the name of a division and prints to standard output the employee names of employees who are directly or indirectly managed by the manager of the division whose name was passed to the procedure.


3) Create a trigger that is invoked when a new row is inserted into the division table. The trigger should enforce the constraint that an employee can be the direct manager of at most one division. Because of the mutating table problem you will not be able to check this constraint by looking directly at the division table. Instead consider the constraint violated if a row is inserted into division with a manager ID value that appears as a manager in the employee table.

---

Gracias.
__________________
I'd rather regret what I did do than what I didn't.
dr_lubin is offline  
Old 10-23-2006, 07:03 AM   #2 (permalink)
Lover - Protector - Teacher
 
Jinn's Avatar
 
Location: Seattle, WA
No offense, but.. do your own homework.

It might suck that they require you to do it, as a graphic designer - but they still require you to do it, not us. Similarly, you're paying for this education (or someone is) and you might as well get some education out of it.

If you want to give me your proposed solutions, I can offer criticism. But I don't think anyone here wants to do it for you.
__________________
"I'm typing on a computer of science, which is being sent by science wires to a little science server where you can access it. I'm not typing on a computer of philosophy or religion or whatever other thing you think can be used to understand the universe because they're a poor substitute in the role of understanding the universe which exists independent from ourselves." - Willravel

Last edited by Jinn; 10-23-2006 at 07:06 AM..
Jinn is offline  
Old 10-23-2006, 07:44 AM   #3 (permalink)
Crazy
 
Understood.

I completely agree. And I guess I did come off that way... my bad.
I don't want anyone to do it for me.

Moving on...

create tables; done.
Trigger, done.

This cursor question, #2 - is where I am having problems.
I think I'm set passing the divName in, and retrieving the employeeID from that division table... Next I'd have to (in speaking terms) take that value and compare it with the Employee table, and store all the matches. Of those matches, I need to run any employee ID's that don't match the initial one, against the entire employee table, and get out those matches - because they would be those employee's indirectly managed by the first division manager passed in. And again for other ID's different in that first result.
I am not finding good cursor examples in my book, class notes, or the web, that can show me how a cursor works, as well as syntax for accomplishing this.


*** edit:

Project done, no problems. Thank god for Google.

I appreciate the moral support.
__________________
I'd rather regret what I did do than what I didn't.

Last edited by dr_lubin; 10-23-2006 at 01:52 PM.. Reason: Automerged Doublepost
dr_lubin is offline  
Old 10-25-2006, 05:04 AM   #4 (permalink)
Junkie
 
Location: Melbourne, Australia
I'm going to take a quick punt (because it's 11pm).

Cursor syntax is simple. What is more difficult, and perhaps what you need to look into - is some of the tricks that can be accomplished with SELECT.

There are usually many many ways to accomplish the same thing... Based on a very quick reading of the question I think you might find the keyword MINUS useful. (You can use it in SELECT). Ditto, NOT IN and EXISTS - but I've always had a particular soft spot for MINUS.

Incidentally, was that the original question wording? They're not keen on punctuation by the look of things.
Nimetic is offline  
 

Tags
pl or sql, sql


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On



All times are GMT -8. The time now is 01:10 PM.

Tilted Forum Project

Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2024, vBulletin Solutions, Inc.
Search Engine Optimization by vBSEO 3.6.0 PL2
© 2002-2012 Tilted Forum Project

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360