二級(vf)sql語句練習(xí)

字號:

1. Stock_sl(股票代碼,買入價,現(xiàn)價,持有數(shù)量)
    Stock_name(股票代碼,股票簡稱,漢語拼音)
    用sql語句完成下列操作:列出所有盈利(現(xiàn)價大于買入價)的股票簡稱、現(xiàn)價、買入價和持有數(shù)量,并將檢索結(jié)果按持有數(shù)量降序存儲于表stock_temp中
    select 股票簡稱,現(xiàn)價,買入價,持有數(shù)量 from stock_sl,stock_name;
    where 現(xiàn)價>買入價 and stock_sl.股票代碼=stock_name.股票代碼 ;
    order by 持有數(shù)量 desc into table stock_temp
    2. 學(xué)生(學(xué)號,姓名,性別,年齡,系)
    課程(科稱號,課程名稱)
    選課(學(xué)號,課程號,成績)
    將選課在5門以上(包括5門)的學(xué)生的學(xué)號,姓名,平均分和選課門數(shù)按平均分降序排序,并將結(jié)果存于數(shù)據(jù)庫表stu_temp(字段名為學(xué)號,姓名,平均分和選課門數(shù))
    方法一:
    select 學(xué)生.學(xué)號,姓名,avg(成績) as 平均分,count(*) as 選課門數(shù) from 學(xué)生,選課;
    where 學(xué)生.學(xué)號=選課.學(xué)號;
    order by 平均分desc;
    group by 選課.學(xué)號 having count(*)>=5;
    into table stu_temp
    方法二:
    select a.學(xué)號,a.姓名,avg(b.成績) 平均分,count(b.課程號) 選課門數(shù) from 學(xué)生 a,選課 b where a.學(xué)號=b.學(xué)號 group by b.學(xué)號 having(count(b.課程號))>=5 order by 平均分 desc into dbf stu_temp
    3. Book(索書號,書名,作者,圖書登記號,價格)
    Borrows(借書證號,姓名,系名,班級)
    Loans(借書證號,圖書登記號,借書日期)
    檢索“田亮”所借圖書的書名、作者、價格,結(jié)果按價格降序存入book_temp中。
    select 書名,作者,價格 from book ,borrows ,loans;
    where 姓名=’田亮’ and borrows.借書證號=loans.借書證號 and loans.圖書登記號=book.圖書登記號;
    order by 價格 desc into dbf book_temp
    4. Score_manager.dbc中,
    Student(學(xué)號,姓名,性別,系部,出生日期)
    Course(課程號,課程名,開課單位,學(xué)時數(shù),學(xué)分)
    Score1(學(xué)號,課程號,成績)
    在score_manager數(shù)據(jù)庫中查詢沒有選修
    任何課程的學(xué)生信息,查詢結(jié)果包括學(xué)號,姓名和系部字段,查詢結(jié)果按升序保存在一個新表new_table中
    select 學(xué)號,姓名,系部 from student where 學(xué)號 not in (select distinct 學(xué)號 from score1) into dbf NEW_TABLE
    5.
    統(tǒng)計選修了課程的人數(shù)(選修多門時,只計算),統(tǒng)計結(jié)果保存在一個新表new_table中,表中只有一個字段:學(xué)生人數(shù)
    select count(distinct(學(xué)號)) 學(xué)生人數(shù) from score1 into dbf NEW_TABLE
    查詢沒有學(xué)生選修的課程,查詢結(jié)果含課程名,開課單位,結(jié)果按課程名勝虛保存在new_tabale2中
    select 課程名,開課單位 from course ;
    where 課程號 not in (select distinct 課程號 from score1) order by 課程名 into dbf NEW_TABLE2
    6.
    (1)首先將book.dbf中所有書名中含有“計算機”三個字的圖書復(fù)制到books_bak中,以下操作均在books_bak中完成。
    (2)復(fù)制后的圖書價格在于價格的基礎(chǔ)上降價5%
    (3)從圖書均價高于25元(含25元)的出版社中,查詢并顯示圖書均價低的出版社名稱以及均價,查詢結(jié)果保存到表new_table4中(字段名為出版單位和均價)
    (1)select * from BOOKS where 書名 like ’%計算機%’ into dbf BOOKS_BAK
    (2)update BOOKS_BAK set 價格=價格*0.95
    (3)select top 1 出版單位,avg(價格) 均價 from BOOKS_BAK group by 出版單位 having avg(價格)>=25 order by