《一网一电大《MySQL数据库应用》实验训练2:数据查询操作MySQL数据库应用.docx》由会员分享,可在线阅读,更多相关《一网一电大《MySQL数据库应用》实验训练2:数据查询操作MySQL数据库应用.docx(14页珍藏版)》请在三一办公上搜索。
1、实验内容:1.单表查询【实验2.1】字段查询(1)查询商品名称为“挡风玻璃”的商品信息。(2)查询ID为1的订单。UWffAfcH4Qd旬a2SCLCCTPWPoppln.014IJW R【实验2.2】多条件查询查询所有促销的价格小于1000的商品信息。nH4,Aig7IG:*1?Sr-rmrtcprt-is.”:。三price(1)查询所有对商品ID为1的商品发表过评论的用户IDoQuery1XGSflOIBOOSIDonlgI*I0皿回1I2SELECTdistinct(Client_cid)FROMcomentwhereAUtoPartSjPidResuRGrid指FAerRows:Ex
2、port:kWrapCelContent:JaCfenJcjd12(2)查询此汽车用品网上商城会员的创建时间段,1年为一段。Ca H A Jl后 11毋*1*1*1I EXPQft; t Wrap Cd 8tent; E2SELECTdistinct(left(CreateTime,)fromclientResultGrid韭*FimrRows;Qeft(Createlime,4)201920182017【实验2.4】ORDERBY(1)查询类别ID为1的所有商品,结果按照商品ID降序排列。HlffAOl0Mg,l%lA陋园1SELCCT*FROMautopartswhereSecdClas&
3、_sdd三jr219orderbyCnaeasjResultGridIFerRows:EtftxPFEXPOCt/Import;WrapC三DContent;ddImageCnamePasswordphore_nuberEnaiGeateameOdrd,1XXXX张三12M5615509871234zs126com2019-01-01sOOrX14XXXX手木子23333333333201911llr3015赵子龙1122222222019-02-03JOOOO2.CZIQnumGJQ31【实验2.5】GROUPBY(I)查询每个用户的消费总金额(所有订单)。I*伊艮。I阳9喀Dlg7金|-Q
4、曲囱RndY4,IQ1SELECTClient_cid,suB(total_price)fromshopping.ordergroubyClienJcid;23RocuhGII杷2HterRovt.IEXpon,UQWnpCdContanti11Qenjddsum(totalj)rice)1232279.92339984S9.98(2)查询类别价格一样的各种商品数量总和。FM3QWliqJCOfMiCIIdJrk,T(APi4)hopplng.4utopArt甲一“StcodClvc!d/PrifIjE0WrW38ct:JEnmJWda“jf(Ad),tt-I夕99S2230BI2 功第t3
5、SDOt4 MSl分析:此查询中需要对商品进行分类,分类依据是同类别和价格,这是多列分组,较上一个例子更为复杂。2.聚合函数查询【实验2.6】COUNTOAfxj1 (1)查询类别的数量。selectcount(Nae)frorshopping.clientkincRMuk Grid gg 弋 Fr R!|。卜1l*r(ordrdttj凡court(Oid)fihooping.ororgrjpbyltft(crdrt,.)IRocuitGrtd3e*O三V:feft-wwCalCorttntz口eftw(fj3aie,JC)count(3d)aoas0301948201909S32019XXI
6、201930-191分析:订单相关,此处使用聚合函数Ce)UNT()和GroUPby子句。查询该商城每天的销售额。钎Iof,(oP.,dte)J(totlJTCU)fchopping.-匚,一/L(oierdate,)RaaA Grid : j Q Ror ft J I Export P WraP S Cant J9 979.999.99NH9gO8R253JDKgl920100920191019分析:在订单表中,有一列是订单总价,将所有订单的订单总价求和,按照下单日期分组,使用SUM()函数和Groupby子句。【实验2.8】AVGO(1)查询所有订单的平均销售金额。1selectavg(t
7、otal_price)frxnshopping.order2ResuhtGridFer Rows;Export: Q I Wrap Ge9 Content; Jaavg(totaljxe)13.728571分析:同上一个相同,还是在订单表中,依然取用订单总价列,使用AVG()函数,对指定列的值求平均数。(I)查询所有商品中的数量最大者。FindV4可叵匚1selectHiax(Inventory)trowshoppingsautopartsResultGridUAfterRovs:rnax(Iventory)分析:商品的数量信息存在于商品表中,此处查询应该去商品表,在商品数量指定列中求值最大者
8、。使用MAX()函数。(2)查询所有用户按字母排序中名字最靠前者。Fhd三|回回叵匚1selectmax(Came)fr。Irshopping,lientjRdIttGrid即FterHowl:Export:WnpClContent:max(Cname)赵子龙分析:MAX()或者MIN()也可以用在文本列,以获得按字母顺序排列的最高或者最低者。同上一个实验一样,使用MAX()函数。Rnd1 Result Grid Rftr Rows:nn(Priee)1.33JI Export: 轮 I Wrap C Content: Ja(I)查询所有商品中价格最低者。selectTin(Price)fro
9、rshopping.autoparts分析:同MAXO用法相同,找到表和列,使用MIN()函数。3.连接查询【实验2.11】内连接查询(1)查询所有订单的发出者名字。4WIAlV.mmIfLUAndHQ.b-Old,b.Cx1chopping.-I八rJ!Uiopplng,11tb、.Clienjcldb.cld三E四四E四 4支3FT平率7分析:此处订单的信息需要从订单表中得到,订单表中主键是订单号,外键是用户ID,同时查询需要得到订单发出者的姓名,也就是用户名,因此需要将订单表和用户表通过用户ID进行连接。使用内连接的(INNER)JolN语句。(2)查询每个用户购物车中的商品名称。分析:
10、购物车中的信息可以从购物车表中得到,购物车表中有用户ID和商品ID两项,通过这两项可以与商品表连接,从而可以获得商品名称。与上一个实验相似,此查询使ffl(INNER)JOIN语句。【实验2.12】外连接查询(1)查询列出所有用户ID,以及他们的评论,如果有的话。stlca.cld.D.comfltcl-cnchopolng.clientaItft1:lnchcoplng.coffr.-tb(、.cldb.cllntcldI rid JU e HU owi: i mts 1邑国情弊2不Ul不依ihq杆得2信评了BBFrpcxti I Wrap Cdl Oxart: 公分析:此查询首先需列出所有
11、用户ID,如果参与过评论的话,再列出相关的评论。此处使用外查询中的LEFT(OUTER)JOIN语句,注意需将全部显示的列名写在JOIN语句左边。(2)查询列出所有用户ID,以及他们的评论,如果有的话。dV.一1,a.cid,srwwt%thcpping.一b,(thcrpi-f*t* 42封解了I4 SSI (wort 0 1 WTW 3 C4fM分析:依然是上一个实验,还可以使用RIGHT(OUTER)JolN语句,注意需将全部显示的列名写在JOlN语句右边。(1)查询用户ID为1的客户的订单信息和客户名。J4八WIP,rMUUSCirit.cavc.b.iFpIshopping.cli?
12、rtaLttjo:nchopping.5rerbga.cd=b.Cllent_cidWhCL二a.cid-4Rat6tdjtFXPCE:IBfPoT:q3IWkC*1OMerr:2un*OidStatueOrdvjcateClnt_6dgoccc.pricecamage_PrCetotaJXdtcta_v*ightZkCtribUorTpIGUM19-09-0933:000一1-2.32CC.33-财张三2subri20W-C%OSJOOOt9.99OOO9.992资到何登分析:复合条件连接查询是在连接查询的过程中,通过添加过滤条件,限制查询的结果,使查询的结果更加准确。此查询需在内查询的基础
13、上加上另一个条件,用户iD为L使用AND语句添加精确条件。(2)查询每个用户的购物车中的商品价格,并且按照价格顺序排列。Rndv.CX卜1 SELECTa.Client-cid,b.PriceFROM2 shopping.Shoppingcartainnerjoinshopping.autopartsbona.autoparts_apid-b.apidorderbyb.pricedescjResultGrid指FHterRews:Export:-WrapCdContent:JXClient-ddPrice4500.981500.982500.983500.9829.991L331L33分析:此
14、查询需要先使用内连接对商品表和购物车表进行连接,得到商品的价格,在使用ORDERBY语句对价格进行顺序排列。4.嵌套查询(1)查询订购商品ID为1的订单ID,并根据订单ID查询发出此订单的用户ID。QUaylSQLFile MbXMfts coonettcetQtdef(wnoc4(t OfdOrJaeao(M&。I。MpfcClsJ I I DOntg1 二elect cid free shooping.client2 nerc Cid in(5 lect CllenT_cld free shopping.ord*1 rere old Ir4 L (select ordr oid free
15、sh090i.order has Jtoparts -mere autoprts apid- 1,)04f Crw1 2B 9 加r Itow, Mt H poftlARpsAt J W5 Cal Canaanti JJ分析:此查询需要使用IN关键字进行子查询,子查询是通过SELECT语句在订单明细表 中先确定此订单ID,在通过SELECT在订单表中查询到用户IDo(2)查询订购商品ID为1的订单ID,并根据订单ID查询未发出此订单的用户ID。select ClieejCid fro shopping.order where oxd,生匕(H OrdeJo 1(3 froa sh。POing.
16、ordc-_s_aUtoPartS Mure aut8artspid. =141 t Hr torn:Jl dt;法 二七 ExpertInport: g & I Wr Cei Cotart: p分析:此查询和前一个实验相似,只是需使用NoTlN语句。(I)查询今年新增会员的订单,并且列出所有订单总价小于100的订单ID。SGLF1*u)c(NrxrtrwMdnt-34SSUld!0_UUCtlU1g。屈Gf*?DertgeQ.1.Fnd-QLF11Cppig.-rClienreidi*(nrridf-rneppi11g.-:*-t,1rt(eretetie,)-,.,)endtotl.pic
17、EB0ryjeOfnaorjnreWaLPrCetoajEMrrbrwi4)ejeVarBJVO1M)TIXlMHWOOMgn12330.032:IaMn3-2SJhm20*8088008198OOO2我,力”222227Mw20100900*00.003992我为总象2ZZ2213Mrw丹及6。9见0cq.Iwtoparts_apldsshopping.or4erJhaswMtopartsg11Mpbyatoprtsj,ld)CShrc.rue*)HMmMMHHHHmHMHHHHHm9HPMHHHHHHMHHHHHMMHMHHH3IClll2Tv9eS:昌由沿8VUBOOfW.WF3COrM
18、rtlQCategoryj,to*eDcscrteCergoryjzjo15卦:M1三,1就5?H2ro.DQicancmam分析:此查询需要进行嵌套查询,子查询过程需要使用到SUM()函数和GRoUPBY求出同种商品的所有被订数量,使用比较运算符得到数量总和小于100的商品ID,再使用比较运算符不等于得到非此商品所在类的类别ID。(1)查询表中是否存在用户ID为100的用户,如果存在,列出此用户的信息。selectroclientw:-cCid-sndcixs(xclcctcidf-onclientKKFCid-)GrdtemeOond(2:查出表丰是否岑在类别ID为100的萃房类三,二果学
19、在.另出二类别丰宝忌少修小于5的套WIDF,“C4tSeceMClMtaUMvcys14分析:EXISTS关键字后面的参数是一个任意的子查询,系统对于查询进行运算以判断它是否返回行,如果至少返回一行,那以EXlSTS的结果为TRUE,此时外层查询语句将进行查询。此查询需要对用户ID进行EXIST操作。(2)查询表中是否存在类别ID为IOo的商品类别,如果存在,列出此类别中商品价格小于5的商品ID。Iliir1AOfiJU4Q工VI,MHKTS3V8*yZr*s(wUMWClMtjcMfr.M*分析:与上一个实验相似,此实验在外查询过程添加了比较运算符。【实验2.17】ANY查询所有商品表中价格
20、比订单表中商品ID对应的价格大的商品IDoWMiMWMMW*WAMBRkMM4rt0WV-8*uISbkIDon?S为观血ib*lectpidfrcautoprt%wherpricvy(%rlcttot】_prir-fromShoppingCrdrb【eftWinOrdgrBs_acopart3Conb.(nd-c.ordejefdWherga.ood-c.pcrt?*VrpBCCrUareB分析:ANY关键字在一个比较操作符的后面,表示若与子查询返回的任何值比较为TRUE,则返回TRUE。此处使用ANY来引出内查询。【实验2.18】ALL查询所有商品表中价格比订单表中所有商品ID对应的价格大
21、的商品ID。1.9I?开Q时DoMg0ITi1 0r-.spid-autcprf%-.aZhL-Ca.price-tctlpric*,rShopping.-T2 lr*tjoi-Order_2$_(WtoperqSconboidc.order-pid,a.utopertsapld)tJdQ,MtoKCgSCC;JQwrap3Goncarts巨11分析:使用ALL时需要同时满足所有内层查询的条件。ALL关键字在一个比较操作符的后面,表示与子查询返回的所有值比较为TRUE,则返回TRUE。此处使用ALL来引出内查询。【实验2.19】集合查询(1)查询所有价格小于5的商品,查询类别ID为1和2的所有
22、商品,使用UNloN连接查询结果。分析:由前所述,UNION将多个SELECT语句的结果组合成一个结果集合,第1条SELECT语句查询价格小于5的商品,第2条SELEcr语句查询类别ID为1和2的商品,使用UNloN将两条SELEcT语句分隔开,执行完毕之后把输出结果组合为单个的结果集,并删除重复的记录。(2)查询所有价格小于5的商品,查询类别ID为1和2的所有商品,使用UNIONALL连接查询结果。1.了hni11iihln11jWSltU=*P.*wISSR.rw23UOJU.*DR&B6S5Bgc|IuggbggaugL,py!Hhnhir!11IHHiHIE11:BaBM,lXKN榨VWg-.MW分析:使用UNle)NALL包含重复的行,在前面的例子中,分开查询时,两个返回结果中有相同的记录,使用UNION会自动去除重复行。UNIC)NALL从查询结果集中自动要返回所有匹配行,而不进行删除。