Heim >Datenbank >MySQL-Tutorial >Fragen zur Datenbankabfrage, die häufig in Java-Interviews auftauchen
Programmierer, die Erfahrung mit Interviews haben, wissen alle, dass der Interviewer Ihnen während des Interviewprozesses alle möglichen seltsamen Fragen stellen kann, aber am Ende müssen Sie die wichtigsten Punkte stellen B. Die grundlegenden Betriebsschritte eines bestimmten Jobs und das Schreiben des Codes usw. In diesem Artikel werden die klassischsten Datenbankabfrageprobleme behandelt.
Grundlegende Tabellenstruktur:
Teacher(tno,tname) Lehrertabelle
student(sno,sname,sage, ssex) student table
course(cno,cname,tno) course table
sc(sno,cno,score) score table
NR.1-Abfragekurs Die Studentenausweise aller Studenten, deren Noten in 1 höher sind als die in Kurs 2
select a.sno from(select sno,score from sc where cno=1) a,(select sno,score from sc where cno=2) bwhere a.score>b.score and a.sno=b.sno
NR.2 Fragen Sie die Studentenausweise und Durchschnittsnoten von Studenten ab, deren Durchschnittsnoten mehr als 60 Punkte betragen
select a.sno as "学号", avg(a.score) as "平均成绩" from(select sno,score from sc) a group by sno having avg(a.score)>60
NO.2 Abfrage aller Studentennummern, Namen, Anzahl der belegten Kurse und Gesamtnoten
select a.sno as 学号, b.sname as 姓名,count(a.cno) as 选课数, sum(a.score) as 总成绩from sc a, student bwhere a.sno = b.snogroup by a.sno, b.sname
oder:
selectstudent.sno as 学号, student.sname as 姓名, count(sc.cno) as 选课数, sum(score) as 总成绩from student left Outer join sc on student.sno = sc.snogroup by student.sno, sname
NO.3 Abfrage der Anzahl der Lehrer mit dem Nachnamen „Zhang ”
selectcount(distinct(tname)) from teacher where tname like '张%‘
oder:
select tname as "姓名", count(distinct(tname)) as "人数" from teacher where tname like'张%'group by tname
NR.4 Fragen Sie die Schülernummer und den Namen von Schülern ab, die die Klasse von „Zhang San“ nicht studiert haben
select student.sno,student.sname from student where sno not in (select distinct(sc.sno) from sc,course,teacher where sc.cno=course.cno and teacher.tno=course.tno and teacher.tname='张三')
NR.5 Abfrage die Studenten, die sowohl Kurs 1 als auch Kurs 2 studiert haben. Studenten-ID, Name
select sno, sname from studentwhere sno in (select sno from sc where sc.cno = 1)and sno in (select sno from sc where sc.cno = 2)
oder:
selectc.sno, c.sname from(select sno from sc where sc.cno = 1) a,(select sno from sc where sc.cno = 2) b,student cwhere a.sno = b.sno and a.sno = c.sno
oder:
select student.sno,student.sname from student,sc where student.sno=sc.sno and sc.cno=1and exists( select * from sc as sc_2 where sc_2.sno=sc.sno and sc_2.cno=2)
NO.6 Fragen Sie die Studenten-IDs aller Studenten ab die alle von „Li Si“ unterrichteten Kurse studiert haben, nennen Sie
select a.sno, a.sname from student a, sc bwhere a.sno = b.sno and b.cno in(select c.cno from course c, teacher d where c.tno = d.tno and d.tname = '李四')
oder:
select a.sno, a.sname from student a, sc b,(select c.cno from course c, teacher d where c.tno = d.tno and d.tname = '李四') ewhere a.sno = b.sno and b.cno = e.cno
NR.7 Fragen Sie die Studentennummern und Namen aller Studenten ab, deren Noten in Kurs Nummer 1 besser sind als diejenigen in Kurs Nummer 2
<p style="font-family: "Microsoft Yahei", "Hiragino Sans GB", Helvetica, "Helvetica Neue", 微软雅黑, Tahoma, Arial, sans-serif; white-space: normal;">select a.sno, a.sname from student a,</p><p style="font-family: "Microsoft Yahei", "Hiragino Sans GB", Helvetica, "Helvetica Neue", 微软雅黑, Tahoma, Arial, sans-serif; white-space: normal;">(select sno, score from sc where cno = 1) b,</p><p style="font-family: "Microsoft Yahei", "Hiragino Sans GB", Helvetica, "Helvetica Neue", 微软雅黑, Tahoma, Arial, sans-serif; white-space: normal;">(select sno, score from sc where cno = 2) c</p><p style="font-family: "Microsoft Yahei", "Hiragino Sans GB", Helvetica, "Helvetica Neue", 微软雅黑, Tahoma, Arial, sans-serif; white-space: normal;">where b.score > c.score and b.sno = c.sno and a.sno = b.sno<br/></p>
NEIN.8 Fragen Sie die Studentennummern und Namen aller Studenten ab, deren Kursergebnisse weniger als 60 Punkte betragen
select sno,sname from studentwhere sno not in (select distinct sno from sc where score > 60)
NEIN. 9 Fragen Sie die Kurse ab, die von Studenten mit mindestens einem Kurs und der Studentennummer 1 belegt wurden. Die Studentennummer und der Name der gleichen Klassenkameraden
select distinct a.sno, a.snamefrom student a, sc bwhere a.sno <> 1 and a.sno=b.sno andb.cno in (select cno from sc where sno = 1)
oder:
select s.sno,s.sname from student s,(select sc.sno from scwhere sc.cno in (select sc1.cno from sc sc1 where sc1.sno=1)and sc.sno<>1group by sc.sno)r1where r1.sno=s.sno
Dies sind die Fragen, die Ihnen in Vorstellungsgesprächen für Datenbankjobs häufig begegnen. Beeilen Sie sich und sammeln Sie sie. Stehen Sie auf und schauen Sie genau hin!
[Empfohlener Kurs: MYSQL-Lernvideo]
Das obige ist der detaillierte Inhalt vonFragen zur Datenbankabfrage, die häufig in Java-Interviews auftauchen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!