WEB开发网      婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄闁挎繂妫Λ鍕⒑閸濆嫷鍎庣紒鑸靛哺瀵鈽夊Ο閿嬵潔濠殿喗顨呴悧鍡樻叏濞戞氨纾藉ù锝呮惈閳诲牏绱掗悩宕囧⒌鐎殿喛顕ч濂稿醇椤愶綆鈧洭姊绘担鍛婂暈闁规瓕顕ч~婵嬪Ω閳轰胶顔夐梺闈涚箳婵厼危閸喓绠鹃柛鈩兠慨鍥ㄣ亜鎼淬垺宕屾慨濠冩そ瀹曘劍绻濋崒姘兼綋闁诲孩顔栭崰鏍偉婵傚摜宓侀柡宥庡幖缁犳稒銇勯弮鍌氫壕闁挎稑绻樺娲川婵犲啫鐦烽梺鍛婃处閸嬪懘鎮鹃鍕拻濞达絽鎽滈弸鍐┿亜椤愩埄妯€鐎规洖缍婂畷绋课旈埀顒傜不閺嶎厽鐓冮柛婵嗗閺嗗﹪鏌涚€n偅宕岀€规洜鍏橀、姗€鎮欓幇鈺佺仾闁靛洤瀚版俊鐑芥晜閸撗呮澖婵犳鍠栭敃銈夊箹椤愶絾娅忛梻浣规偠閸庢粓鍩€椤掑嫬纾婚柟鐐窞閺冨牆宸濇い鎾跺缁遍亶姊绘担绛嬫綈鐎规洘锕㈤、姘愁槼妞ゃ垹锕缁樻媴閸涘﹤鏆堝┑鐐额嚋缁犳挸鐣疯ぐ鎺戠妞ゆ柨褰炵粭澶娾攽閻愭潙鐏熼柛銊︽そ閹繝寮撮悢缈犵盎闂佽婢樻晶搴g矙閼姐倗纾奸柍褜鍓熷畷姗€鍩炴径鍝ョ泿闂佺澹堥幓顏嗘閺囩喐娅忓┑鐘愁問閸犳牠鏁冮妸銉㈡瀺闁挎繂娲ら崹婵囩箾閸℃绠氶柡瀣叄閺岀喖顢涢崱妤€鏆欐い銉﹀姍濮婂宕掑▎鎴М闂佺濮ょ划宥夊箞閵娾晜鍋ㄧ紒瀣硶椤︻喖鈹戦悙鍙夘棡闁告梹甯為幑銏ゅ幢濞戞瑧鍘介梺闈涚箚閹虫岸宕烽鐘电劶闁诲函缍嗛崑浣圭濠婂牊鐓涚€广儱鍟慨鈧繝銏n潐閿曘垽寮诲☉銏″€锋い蹇撳椤洤鈹戦纭锋敾婵$偠妫勮灋闁告劦鐓佽ぐ鎺懳ч柛鈩冪憿婵洭姊洪悷鏉挎Щ闁硅櫕锕㈤悰顕€骞樼拠鑼唺閻庡箍鍎遍幏瀣涘⿰鍫熲拻闁稿本鐟чˇ锔界節閳ь剟鏌嗗鍛紵闂侀潧鐗嗛ˇ顓㈠焵椤掆偓閸熸潙鐣烽崡鐐╂婵☆垳鍘ч獮鍫ユ⒒娴e憡璐¢柛搴涘€濋妴鍐幢濞戞瑥浜楅梺鍝勬储閸ㄦ椽鎮″☉銏$厱闁靛绲介崝姘攽閿涘嫬甯堕棁澶嬬節婵犲倸顏柣顓烆儔閺屾洟宕惰椤忣剛绱掗悩宕囨创闁轰焦鍔欏畷銊╊敇閻樺灚缍侀梻鍌氬€风粈渚€骞栭锝呯窞闁搞儺鍓欓悞鍨亜閹哄棗浜剧紒鍓ц檸閸欏啫顕i幎钘夊耿婵炴垶鐟ラ埀顒傛暬閺屻劌鈹戦崱娑扁偓妤€顭胯閸楁娊寮婚敓鐘插耿婵炲棗绻嗛弸鍛存⒑閸濆嫮娼ら柛鏇ㄥ亽閸ゃ倕鈹戦悙鍙夘棡闁搞劎鏁诲畷鍝勭暆閸曨兘鎷洪梻鍌氱墛缁嬫帡藟閻愮儤鍋ㄦい鏍ㄧ☉濞搭噣鏌ㄥ┑鍫濅粶闁宠鍨归埀顒婄秵閸嬪嫭绂嶅Δ鍛厵闁煎湱澧楄ぐ褏绱掗幓鎺嬪仮闁诡喕绮欓幊锟犲Χ閸モ晪绱冲┑鐐舵彧缂嶁偓妞ゆ洘鐗曢埢鎾诲即閵忥紕鍘遍梺闈浨归崕铏閵徛颁簻妞ゆ劑鍨荤粻宕囩磼鏉堛劌绗掗摶锝夋偣閸パ勨枙闁逞屽墯閹稿墽妲愰幘瀛樺闁革富鍘稿Σ鍫濐渻閵堝棗鐏ラ柟鍐查叄閸┿垽骞樺ú缁樻櫍闂佺粯鍔忛弲婊堝棘閳ь剚淇婇悙顏勨偓鏍ь潖瑜版帒鍑犲┑鐘宠壘缁€鍌涖亜閹烘垵鈧崵澹曟總鍛婄厽婵☆垱瀵ч悵顏嗏偓瑙勬礀閻倿寮婚弴銏犲耿闁哄洨濯Σ顔碱渻閵堝骸浜濈紒璇茬墦閻涱噣宕堕妸锕€顎撻梺绋跨箰椤︿即鎮楅崨濠勭瘈闁汇垽娼у暩闂佽桨绀侀幉锟犲箞閵娾晩鏁囬柕蹇曞Х閿涙盯姊虹憴鍕缂佸鍠涢妵鎰板箳閹惧瓨鐝抽梻浣规偠閸庮噣寮崒鐐茬劦妞ゆ巻鍋撻柨鏇ㄤ邯瀵鏁撻悩鑼姦濡炪倖甯婇懗鍫曘€呴悜鑺ュ€甸柨婵嗛娴滅偤鏌涘Ο鎸庮棄闁宠鍨块崺銉╁幢濡ゅ啩鐢绘俊鐐€栭崹鍫曟偡閳轰胶鏆﹂柣銏㈩暯閸嬫捇鏁愭惔鈥冲箣闂佺ǹ顑嗛幐楣冨箟閹绢喖绀嬫い鎺嗗亾濞寸姭鏅犲铏圭矙閹稿骸鏀紓渚囧櫍缁犳牠骞冨鈧畷姗€顢欑憴锝嗗缂傚倸鍊烽悞锕傚煟閵堝鏁傞柛鏇㈡涧濞堛劑姊洪崜鎻掍簼婵炲弶鐗犻幃鍧楊敋閳ь剟寮婚敐澶婄疀妞ゆ棁濮ゅВ鍕磼閻愵剙鍔ら柕鍫熸倐瀵鈽夊顐e媰闂佺粯鍔﹂崜娑樷枔閵堝鐓涘ù锝呮憸婢э箓鏌熼绛嬫畼闁瑰弶鎸冲畷鐔碱敆閸屻倖袨缂傚倸鍊风欢锟犲窗閺嶎偅宕叉俊顖涘椤ャ倝姊虹拠鏌ュ弰婵炰匠鍥х婵犲﹤鍚樺☉銏╂晬闁绘劕顕崢闈涱渻閵堝棛澧俊顐f⒒缁牊鎷呴崷顓ф祫濡炪倖娲嶉崑鎾绘煙椤旂瓔娈旈柍缁樻崌瀹曞綊顢欓悾灞奸偗闂傚倷鑳剁划顖炴偋濠婂牆鍌ㄧ憸鏃堝箖妤e啯鍊婚柤鎭掑劚娴滄鏌熼悡搴f憼閽冭鲸銇勯銏⑿㈤柍瑙勫灴閸┿儵宕卞Δ鍐ф埛闂佽崵濮崑鎾绘煥閺囩偛鈧綊宕愰悽纰樺亾鐟欏嫭绀€婵炲眰鍔庢竟鏇熺鐎n偆鍘遍柣蹇曞仜婢т粙骞婇崨瀛樼厱闁哄倽娉曟牎闂侀潧娲ょ€氱増淇婇幖浣肝ㄩ柨鏃傜帛椤ワ綁姊绘担椋庝覆缂佹彃澧介幑銏ゅ醇閵壯冪ウ闂佸搫绉查崝宥嗗垔鐎涙ɑ鍙忔繝闈涙濠€浼存煙闊厼宓嗘慨濠勭帛閹峰懘鎼归悷鎵偧婵犵妲呴崑鍕疮绾惧锛傞梻浣筋潐瀹曟﹢顢氳鏁堥柡灞诲劜閸婄敻鏌ㄥ┑鍡涱€楅柡瀣枛閺岋綁骞樼捄鐑樼€炬繛锝呮搐閿曨亝淇婇崼鏇炵<婵﹩鍋勯ˉ姘舵⒒閸屾瑨鍏岀紒顕呭灦閵嗗啴宕ㄩ鍥ㄧ☉铻栭柛娑卞幘閸樻椽姊洪崷顓炰壕缂佸墎鍋ゅ顕€宕煎┑鍡欑崺婵$偑鍊栧Λ渚€锝炴径灞稿亾濮橆兙鍋㈡慨濠冩そ閹筹繝濡堕崨鍛灪缁绘盯鎳犻鈧埢鍫ユ煕閳规儳浜炬俊鐐€栫敮鎺楀疮椤栫偞鍋熸い蹇撶墛閻撶喖鐓崶褝宸ュù婊堢畺濮婂宕掑顑藉亾妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晝閳ь剛绮婚悩缁樼厵闂侇叏绠戦獮妤呮煕濞嗗繒绠婚柡宀€鍠撶槐鎺楀閻樺磭浜堕梻浣呵归鍌炲疾閻樿钃熼柨婵嗩槸鍥撮柟鑹版彧缁辨洘绂掑⿰鍕閻庢稒岣块惌濠勭磽瀹ュ拑韬€殿喖顭烽幃銏ゅ礂閻撳簶鍋撶紒妯圭箚妞ゆ牗绻傛禍褰掓煟閿濆棙銇濇慨濠冩そ瀹曨偊宕熼鈧▍銈囩磽娴g瓔鍤欓柣妤€妫濋敐鐐剁疀閹句焦妞介、鏃堝椽娴h妫冨┑鐘垫暩閸嬬偤宕归崼鏇熷殞濡わ絽鍟ㄩ埀顒€鍊垮畷顐﹀礋閵婏附鏉搁梻浣哥枃濡嫬螞濡や胶顩叉繝闈涱儐閻撶喖鏌i弬鍨骇婵炲懎锕弻鏇㈠幢閺囩媭妲梺瀹狀嚙闁帮綁鐛幒妤€绫嶉柛灞剧⊕缁额偊姊婚崒娆戭槮闁圭⒈鍋婂畷顖烆敃閿曗偓绾剧懓鈹戦悩宕囶暡闁稿骸锕弻娑㈩敃閻樻彃濮曢梺鎶芥敱閸ㄥ爼骞堥妸鈺傚仭闁绘鐗婇幃娆撴⒑鐠囪尙绠扮€殿喖澧庨幑銏犫槈濞嗘劕顎撻梺鍛婂姈瑜板啴顢旈锝冧簻闁冲搫鍟崢鎾煛鐏炶濮傜€殿喗鎸抽幃娆徝圭€n亙澹曢悷婊呭鐢宕戦崒鐐寸厸闁搞儯鍎遍悘顏堟煟閹惧磭绠伴柍瑙勫灴閹瑩鎳犻鑳闂備礁鎲¢弻锝夊磹濠靛钃熸繛鎴欏灩閻撴盯鎮楅敐搴″閽冭鲸淇婇悙顏勨偓鎴﹀礉婵犲洤纾块柣銏⑶圭粻鏍ㄧ箾閸℃ɑ灏紒鐙欏洦鐓欓悗娑欋缚缁犮儲绻涢崗鑲╊暡濞e洤锕俊鍫曞炊椤喓鍎甸弻娑氣偓锝庡墮娴犻亶鏌℃担绋挎殻濠殿喒鍋撻梺闈涚墕閸熺娀宕戦幘瀛樺缂侇垱娲橀悗濠氭⒑閸︻厼浜炬繛鍏肩懃閳绘捇骞囬悧鍫氭嫼闂佸憡鍔曞鍫曞箚閸喆浜滈柟瀛樼箖閸犳﹢鏌e☉鍗炴珝濠殿喒鍋撻梺闈涚墕濡矂骞忔繝姘拺缂佸瀵у﹢浼存煟閻曞倸顩紒顔硷躬閹囧醇濞戞鐩庢俊鐐€栭崝鎴﹀春閸曨倠锝夊箹娴e湱鍘介梺鎸庣箓閹冲骸危婵犳碍鎳氶柨婵嗩槹閻撶姵绻涢弶鎴剱婵炲懎娲弻锝夊箻閹颁礁鍓板銈庝簻閸熷瓨淇婇崼鏇炲耿婵妫欓埛鏍⒒娴h姤纭堕柛鐘叉瀹曟洟鎳犻鍌滅効閻庡箍鍎遍悧鍕瑜版帗鐓欓柣鎴炆戠亸鐢告煕濡吋鏆慨濠呮缁辨帒螣閾忛€涙闂佽棄鍟存禍鍫曞箖濡法鐤€闁挎繂鎳庣粻褰掓⒒閸パ屾Ч缂佺粯绻冪换婵嬪磼濮橆厽顔嶇紓鍌欑椤﹂亶宕曢妶澶婄疄闁靛⿵濡囩弧鈧梺鍛婁緱閸n喗绂掗埡鍐=濞达絼绮欓崫娲偨椤栨稑绗╅柣蹇斿浮濮婃椽骞嗚缁犲鏌嶈閸撴氨绮欓幒妞尖偓浣割潨閳ь剙顫忔繝姘<婵炲棙鍨垫俊浠嬫煟鎼达絿鎳楅柛蹇曞Т閹碱偊顢橀崗鐓庣窞濠电姴瀚悡锝嗙節閻㈤潧浠﹂柛銊ュ閸掓帗鎯旈姀銏╂锤闂備緡鍓欑粔鐢稿煕閹烘嚚褰掓晲閸涱喖鏆堥梺鍝ュ枔閸嬬偟鎹㈠☉姘珰鐟滃繘鎮鹃悽纰樺亾鐟欏嫭绀€缂傚秴锕濠氬幢濡ゅ﹤鎮戦梺鍛婁緱閸ㄤ即鐛崼銉︹拻濞达絼璀﹂弨浼存煙濞茶閭慨濠佺矙瀹曠喖顢涘☉妯圭暗婵犵數鍋涘Λ娆撳箰婵犳碍鍋傞柣妯虹-缁犻箖鏌℃径瀣劸闁稿孩鍔栫换娑㈠川椤撶喎娅i梻鍥ь樀閺岋絽螣閾忕櫢绱為梺娲诲幖閿曨亪寮诲鍥ㄥ枂闁告洦鍋嗘导宀勬⒑閹肩偛濮傜紒鐘崇墵楠炲啫鈻庨幘鏉戠檮婵犮垼娉涢ˇ顖炲垂濠靛鈷掗柛灞剧懄缁佺増銇勯弴鐔哄⒌鐎规洘婢樿灃闁告侗鍋€閸嬫捇宕橀鐓庣獩闂佸搫顦伴崹褰掑矗閳ь剙鈹戦悩顔肩伇闁糕晜鐗犲畷婵嬪即閻樺吀绗夐梺瑙勫劶婵倝鎮″▎鎾寸厵妞ゆ牕妫楅懟顖氣枔閸洘鍋℃繝濠傚缁跺弶绻涚仦鍌氬婵″弶鍔欓獮妯兼嫚閼碱剨绱叉繝鐢靛仜濡瑩宕归懖鈺冪幓婵°倕鎳忛埛鎴︽煕濠靛嫬鍔氶弽锟犳⒑缂佹﹩娈樺┑鐐╁亾闂侀潧妫旂欢姘嚕娴犲鏁囬柣鎰皺閻涒晠姊绘担鍛婅础闁冲嘲鐗撳畷銏$鐎n亞鏌ч梺鎸庣箓椤︿即鍩涢幋鐘电<閻庯綆鍘界涵鍓佺磼閻樺啿鈻曢柡灞剧☉铻i柣妯哄级閸g儤銇勯幇顏嗙煓闁哄矉缍侀獮鍥敊閸撗呮缂傚倷娴囬褍螞濞嗘挸桅闁告洦鍨伴崘鈧梺闈浤涢崨顖氬笓闂備焦鐪归崺鍕垂鏉堚晝鐭欓柟鐑樻⒐瀹曞弶绻涢幋娆忕仼鐎瑰憡绻冮妵鍕箻鐠虹儤鐎婚梺鍝勵儑婵挳鍩為幋锔绘晩缁绢厼鍢叉慨娑氱磽娓氬洤娅橀柛銊ョ埣閻涱喛绠涘☉妯虹獩闁诲孩绋掗敋濞寸媭鍙冨缁樼瑹閸パ冧紟缂備胶濮甸崹鐢稿煝閹炬枼鏀介柛顐犲灮閿涙繈姊虹粙鎸庢拱闁荤噦濡囩划濠囨偋閸稐绨婚梺鍝勬搐濡煤閵堝洤顥氱憸鐗堝笚閻撴洘銇勯鐔风仴婵炲懏锕㈤弻娑㈠Χ閸℃ḿ顦紓浣介哺閹稿骞忛崨顖涘妞ゆ牗绮庣粣妤冪磽閸屾瑨顔夋俊鐙欏洤纾婚柟鍓х帛閳锋帒霉閿濆牜娼愰柛瀣█閺屾稒鎯旈鑲╀桓閻庤娲樼换鍌烆敇婵傜ǹ宸濇い蹇撴噽閳ь剚妞藉娲箹閻愭彃濮堕梺鍛婃尰瀹€鎼佸春濞戙垹绠i柣妯兼暩閿涙粓鏌f惔顖滅У闁稿瀚伴、姘堪閸曨厾鐦堥梺閫炲苯澧存鐐茬Ч椤㈡瑩宕滆缁辨煡姊虹拠鎻掑毐缂傚秴妫濆畷鎴﹀川椤撶姵娈鹃悗鍏夊亾闁逞屽墴閸┾偓妞ゆ帒鍠氬ḿ鎰箾閹绘帞绠荤€规洝顫夌粋鎺斺偓锝庝簽閻g儤绻涚€电ǹ孝妞ゆ垵鎳庨蹇撯攽閸″繑鏂€闂佺粯蓱瑜板啴顢旈埡鍌ゆ闁绘劖鎯屽▓婊勬叏婵犲啯銇濋柟顔惧厴瀵爼骞愭惔鈾€鍋撻鐐粹拺濞村吋鐟х粔闈浢瑰⿰搴濈盎闁伙綁顥撻幉鎾礋椤撶姷妲囨繝娈垮枟閿曗晠宕滃☉銏犲偍闁规壆澧楅埛鎴︽煕濠靛棗顏柛灞诲姂閺屾盯濡搁敂濮愪虎闂佽鍣换婵囦繆閻戣姤鏅滈柦妯侯槸娴煎孩绻濈喊妯活潑闁搞劋鍗抽幃妯衡攽鐎n偄浜楅梺瑙勫婢ф鎮¢悢鍏肩厵闁硅鍔栫涵楣冩煛鐎n偆娲撮柡宀嬬秮楠炴瑩宕橀妸銈呮瀳闁诲氦顫夊ú鏍偉閸忛棿绻嗛柣鎴f鍞梺闈涱槶閸庢盯骞嬮悩鐢碉紳闂佺ǹ鏈悷褔藝閿斿浜滈柟瀛樼箘婢ф洟鏌i敐鍥у幋闁诡喕绮欏畷褰掝敃椤愶絿绋愰梻鍌欑濠€閬嶅磿閵堝拋娼栭柤濮愬€曢ˉ姘舵煕韫囨稒锛熺紒璇叉閵囧嫰寮介妸褏鐣垫繛瀛樼矊缂嶅﹪寮婚敐澶嬫櫜闁割偆鍣ユ禒鈺冪磽娴d粙鍝洪柟绋款煼楠炲繘宕ㄧ€涙ɑ鍎梺鑽ゅ枑婢瑰棝顢曢懖鈺冪=闁稿本鐟︾粊鐗堛亜閺囧棗娲﹂崑瀣煕閳╁啰鈯曢柛瀣ф櫇閳ь剛鎳撶€氫即宕戞繝鍌栫細闁靛ň鏅滈悡鍐喐濠婂牆绀堟慨姗嗗幘閳瑰秴鈹戦悩鎻掍簽婵炲吋澹嗛埀顒€鍘滈崑鎾斥攽閻樻彃鏁柕濞у懐锛濋梺绋挎湰閻燂妇绮婇弶娆炬富闁哄鍨堕幉鎼佹煙楠炲灝鐏茬€规洜鍘ч埞鎴﹀箛椤撶姷鈻夌紓鍌氬€搁崐鐑芥倿閿曚焦鎳屽┑鐘愁問閸ㄤ即顢氶鐘愁潟闁圭儤鍨熷Σ鍫熸叏濡も偓濡宕滈弶搴撴斀闁绘劘灏欐晶娑㈡煕閺冣偓閻熴儵锝炶箛鎾佹椽顢旈崟顓у晣闂備胶绮崝鏍亹閸愵喒鈧牠宕卞☉娆屾嫼闂佸憡绋戦オ鏉戔枔閺冨牊鐓曢柣鏃堟敱閸嬨儵鏌熼鈧粻鏍箖濠婂懐椹抽悗锝庡亝濞呮牠姊绘担铏瑰笡闁告梹岣挎禍绋库枎閹板灚顔旈梺鎼炲労閸撴岸鍩涢幋锔界厽闁绘梻鍘ф禍浼存煕閵堝洤鏋庨柍瑙勫灴椤㈡岸鍩€椤掆偓宀h儻顦归柛鈹垮灲楠炴ê菐椤掆偓娴滄繈姊洪崨濠傚闁哄倷绶氶獮蹇涙惞閸︻厾锛濋梺绋挎湰閻熝囧礉瀹ュ瀚呴梺顒€绉甸悡鍐⒑閸噮鍎忔繛鎼櫍閺岋紕浠﹂悾灞濄垽鏌i敐蹇曠瘈妤犵偛绉归、娆戜焊閺嵮冪阀闂備浇顕х€涒晠顢欓弽顓為棷妞ゆ洍鍋撶€规洘鍨剁换婵嬪磼濠婂嫭顔曢梻浣告贡閸庛倝銆冮崱娑樼9闁绘垼濮ら崐鐢告煟閵忋垺顏㈢憸鐗堝笧瀹撲線鏌涢鐘插姕闁抽攱甯掗湁闁挎繂娲﹂崵鈧梺宕囩帛濞茬喖寮婚埄鍐懝闁搞儜鍕綆闁诲氦顫夊ú姗€宕归崸妤冨祦婵☆垵鍋愮壕鍏间繆椤栨粌甯舵鐐村姍濮婄粯鎷呴崨濠傛殘婵炴挻纰嶉〃濠傜暦閺夋娼╅悹楦挎閻ゅ洭姊洪崨濠佺繁闁哥姵娲滈幑銏ゅ幢濞戞瑧鍘卞┑鐐叉濞存艾危缁嬪簱鏀芥い鏂垮悑閸犳﹢鏌熼挊澶屽煟闁轰焦鍔栧鍕偓锝庝簷閸濇绻濋悽闈涗沪闁搞劌澧庨弫顕€骞掗幘瀛樼彿闂佸搫琚崕鏌ユ偂濞戙垺鐓曢悘鐐佃檸濞堟柨霉濠婂牏鐣烘慨濠傤煼瀹曟帒顫濋钘変壕闁绘垼濮ら崵鍕煕閹捐尙顦﹂柛銊︾箖閵囧嫰寮介顫捕缂備讲鍋撳鑸靛姈閻撴盯鏌涢妷銏℃珔闁逞屽墾缂嶄線骞冮姀銈呬紶闁靛/鍛潓闂傚倷鐒﹂幃鍫曞磿濠婂牆绀冮柍杞扮婵啴姊婚崒姘偓鐑芥嚄閸撲礁鍨濇い鏍仜閽冪喖鏌曟繛鐐珕闁稿骸绉电换婵嬫濞戝崬鍓扮紓鍌欒閺呯娀寮婚妶澶婄畳闁圭儤鍨垫慨灞剧箾鐎涙ḿ鐭嬬紒顔芥崌瀵鏁撻悩鑼槰闂侀潧饪电粻鎴λ囬埡渚囨富闁靛牆鍟崝姘亜閿旂偓鏆€殿喛顕ч埥澶愬閻樻剚妫熼梺鑽ゅТ濞诧妇绮婇幘顔肩;闁圭偓鏋奸弨浠嬫倵閿濆簼绨芥い鏃€鍨垮娲礈閹绘帊绨煎┑鐐插级閿曘垹鐣烽幇鐗堝€婚柤鎭掑劤閸樹粙姊洪悷閭﹀殶闁稿绉剁槐鎾愁潩閼哥數鍘卞┑顔姐仜閸嬫挸霉濠婂棙纭炬い顐㈢箰鐓ゆい蹇撳缁卞爼姊洪崨濠冨闁告挻鐟╁畷鎴濐吋婢跺鎷洪梺鍛婄☉閿曘儵鎮¢妷鈺傜厸闁割偒鍋勬晶瀵糕偓娈垮枟閻撯€崇暦婵傜ǹ鍗抽柕濠忛檮濞呮牠姊绘担铏瑰笡闁告梹娲熼、姘额敇閵忕姴鍋嶉梺鍛婎殘閸嬫劙寮ㄦ禒瀣厽闁归偊鍓欑痪褎銇勯妷锔剧煂缂佽鲸甯炵槐鎺懳熼搹璇″剬缂傚倷绶¢崰姘卞垝椤栨粍宕叉繝闈涙-濞尖晜銇勯幘璺盒㈡鐐村姍濮婅櫣鎷犻懠顒傤唺闂佺ǹ顑囬崰鏍ь嚕閺屻儺鏁冮柨婵嗘閻濓繝姊绘担绛嬪殭婵﹫绠撻敐鐐村緞婵炴帗妞介弫鍐磼濮樻唻绱卞┑鐘垫暩婵挳宕愭繝姘辈闁挎洖鍊归悡鐔兼煛閸愩劌鈧敻骞忛敓鐘崇厸濞达絽鎲¢ˉ銏ゆ煛鐏炵晫啸妞ぱ傜窔閺屾盯骞樼€靛憡鍣伴梺绯曟杺閸ㄥ綊顢橀崗鐓庣窞閻庯綆鍋呴悵鎶芥⒒娴h鍋犻柛搴櫍瀵彃鈹戠€n偅娅栧┑鐘绘涧濞层劎绮绘ィ鍐ㄧ骇闁割偅绻傞埛鏃傜磼鐎n厼鍚归柟鍙夋倐瀵爼宕归鑺ヮ唹缂傚倷绀侀崐鍝ョ矓瑜版帒绠栨繛鍡樻惄閺佸棝鏌涚仦鍓х煂婵℃彃娲缁樼瑹閳ь剙岣胯椤ㄣ儴绠涢弴鐐电瓘闂佸憡鎸嗛崟顐㈠箲闂備胶绮崝锕傚礂濞嗘劗顩叉繝濠傜墛閻撴瑩鎮楀☉娆嬬細缂佺姵鐗滈埀顒傛嚀閹诧紕鎹㈤崟顓燁潟闁圭儤顨忛弫濠囨煕閹炬鍟伴濂告⒒娓氣偓濞佳囨偋閻愮數绀婂ù锝呮憸閺嗭附鎱ㄥ璇蹭壕闂佺硶鏅换婵嗙暦濮椻偓婵℃悂濡疯閸氬姊婚崒姘偓宄懊归崶顒夋晪鐟滃繘鍩€椤掍胶鈻撻柡鍛箘閸掓帒鈻庨幘宕囶唺闂佺懓顕慨瀵哥不閻㈠憡鐓熼柣妯哄帠閼割亪鏌涢弬鍨劉缂佸顦濂稿幢濡搫浼庢繝纰夌磿閸嬬娀顢氳缁傚秵銈i崘鈹炬嫼闂佸憡绻傜€氼垶锝為敃鍌涚厱闁哄倽娉曢悞鎼佹煕閳瑰灝鍔滅€垫澘瀚换娑㈠閵忕姵鐎鹃悗鍨緲鐎氫即骞嗛崒鐐蹭紶闁靛鐏栭幋锔解拺闂傚牊绋掗幖鎰版倵濮樺崬顣煎ǎ鍥э躬楠炴牗鎷呯憴鍕彸闂備礁鎲℃笟妤呭储閼归偊鏉洪梻鍌氬€搁崐宄懊归崶顒夋晪闁哄稁鍘肩粣妤佷繆閵堝懏鍣洪柛瀣剁節閺屽秹宕崟顒€娅¢梺閫炲苯鍘哥紒鑸佃壘椤曪綁顢氶埀顒€鐣烽悡搴樻斀闁割偒鍋呮晥婵犵绱曢崑鎴﹀磹閺嶎厼绠伴柤濮愬€栧畷鏌ユ煕閺囥劌骞橀柣顓炴閺屾盯寮撮妸銉т画闂佹娊鏀辩敮锟犲蓟濞戞矮娌柛鎾楀嫬娅楃紓鍌欐閼宠埖鏅跺Δ鍛﹂柛鏇ㄥ灠閸楁娊鏌i弬鎸庢儓闁冲嘲鐭傞幃妤冩喆閸曨剛锛涢梺鍛婎殔閸熷潡顢氶敐鍡欘浄閻庯絽鐏氶弲婵嬫⒑闂堟稓澧曟繛鏉戝€稿嵄缂佸绨遍弨浠嬫煟濡櫣浠涢柡鍡忔櫅閳规垿顢欓懞銉ュ攭閻庤娲橀崝鏍崲濠靛棭娼╂い鎺嶆祰缁躲垽姊绘担鐟邦嚋婵炲弶鐗犲畷鎰亹閹烘挸浜楀┑鐐叉閸旀垶绂嶅⿰鍫熺厸鐎广儱楠告禍婊兠归悩宕囩煀闂囧绻濇繝鍌涘櫣妞わ絿鍘ц彁闁搞儜宥堝惈闂佺懓纾慨鐢告晬閹邦兘鏀介柛鈩冿供閸炴煡姊婚崒娆戭槮闁汇倕娲敐鐐村緞閹邦剙鐎梺绉嗗嫷娈旈柡鍕╁劦閺屾盯寮撮妸銉т哗缂備讲鍋撻柛鎰靛枟閻撳繐鈹戦悙鎴濆暞閸g兘鏌涚€Q€鍋撻弬銉︽杸闂佹寧绋戠€氼剚绂嶆總鍛婄厱濠电偛鐏濋埀顒佺箓閻g兘濮€鎺抽崑鍛存煕閹扳晛濡挎い蟻鍐f斀闁宠棄妫楅悘鐔兼偣閳ь剟鏁冮崒姘優闂佸搫娲㈤崹娲磻閿濆鐓曢柕澶涚到婵″潡鏌曢崼婵堟憼濞e洤锕獮鎾诲箳閺傚簱鍙洪梻浣告惈閺堫剙煤濠靛牏涓嶆繛鎴欏灩閸楁娊鏌i幋婵囶棡缂傚秴鐭傚缁樻媴缁嬫寧姣愰梺鍦拡閸嬪﹪鐛繝鍛杸婵炴垶鐟ユ禍妤呮椤愩垺澶勯柟灏栨櫊閹垽宕卞☉娆忎化婵°倧闄勭€笛囶敂閻樺樊鐔嗙憸搴∶洪悢鐓庤摕婵炴垯鍨圭猾宥夋煃瑜滈崜鐔肩嵁閹版澘绠柦妯侯槼閹芥洖鈹戦悙鏉戠仧闁搞劎鎳撹灋婵☆垵宕电粻楣冩煕閳╁啰鎳冨ù婊勫劤铻栭柡鍐ㄥ€荤壕浠嬫煕鐏炲墽鎳勭紒浣规緲椤啰鈧稒蓱閸婃劖顨ラ悙鏉戝缂佺粯绻傞~婵嬵敆閸屻倕鏁搁梻鍌欑閹测剝绗熷Δ鍛瀭闁规儼濮ら崕妤佺箾閸℃ɑ灏紒鐘茬秺閹鈽夊▍铏灩娴滄悂顢橀悘鑽ゆ嚀楗即宕奸姀銏℃瘒闂備礁鎼張顒傜矙閹达箑鐓橀柟杈剧畱缁€瀣亜閹扳晛鐏╃悮姗€姊婚崒娆戝妽婵$偛娼″畷銏$鐎n亞顔囨俊銈忕到閸燁偆绮婚悢鍏肩厵闂傚倸顕崝宥夋煕鐎n亶鍎旈柡灞剧洴椤㈡洟鏁愰崶鈺冩毉闂備浇宕甸崰鍡涘礉閹存繍娼栨繛宸簻娴肩娀鏌涢弴銏℃锭闁告搩鍠氱槐鎾存媴閽樺鍘悗鍏夊亾缂佸顑欓崵鏇炩攽閻樺磭顣查柛瀣閺岋綁骞橀搹顐e闯濡炪倧瀵岄崣鍐箖瀹勬壋鍫柛鎰典簽椤斿﹪姊烘潪鎵窗闁哥姵鐗犻崺銉﹀緞閹邦剦娼婇梺鎸庣☉鐎氼剟鐛幇鐗堚拻濞达絽鎲¢崯鐐层€掑顓ф疁鐎规洘婢樿灃闁告侗鍘鹃敍娆撴⒑鐟欏嫬顥嬪褎顨婇幃鈥斥槈閵忊€斥偓鍫曟煟閹伴偊鏉洪柛銈嗙懃閳规垿顢欓悡搴樺亾閸ф钃熼柣鏃傗拡閺佸﹪鏌涘┑鍡楊仱闁稿鎸搁埞鎴﹀幢濞嗘劖顔曢梻浣告贡閸庛倝宕归悢鑲猴綁宕奸悢绋垮伎濠德板€愰崑鎾翠繆椤愶絾鈷掓俊鍙夊姍閺佹捇鏁撻敓锟� ---闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鏁愭径濠勵吅闂佹寧绻傞幉娑㈠箻缂佹ḿ鍘辨繝鐢靛Т閸婂綊宕戦妷鈺傜厸閻忕偠顕ф慨鍌溾偓娈垮櫘閸o絽鐣锋總鍛婂亜闁告稑饪撮崬鍫曟⒒閸屾瑨鍏岄弸顏呫亜閹存繃顥㈡鐐村姍瀹曟粏顦查柛銊︾箖閵囧嫰骞樼捄杞版睏濠碘剝褰冮悧濠冪┍婵犲浂鏁嶆慨姗嗗幗閸庢挾绱撴担鍝勑い鏇嗗洤鐓橀柟杈鹃檮閸婄兘鏌涘▎蹇fТ闁哄鐟︾换娑氣偓娑欋缚閻绱掗鑺ュ磳妤犵偛鍟撮崹楣冨棘閵夛富娼旈梻渚€娼ф蹇曟閺囥垹鍌ㄩ柛妤冨亹閺€浠嬫煟閹邦厽缍戦柣蹇嬪劤閳ь剝顫夊ú锕傚礈閻斿吋鍋樻い鏂挎閻旀哺褔宕堕敂鍓ф晨闂傚倷绀侀幖顐﹀磹閸︻厸鍋撶粭娑樻硽婢舵劕顫呴柍鈺佸暙瀵寧绻濋悽闈浶㈤柟鍐茬箻椤㈡棃鎮╃紒妯煎幍闂佽崵鍠愬姗€顢旈鐐╂斀闁斥晛鍟崐鎰攽閿涘嫬鍘撮柡浣稿€块獮鍡氼槾缂佸鐗撳濠氬磼濮橆兘鍋撻悜鑺ュ殑闁割偅娲栫粻鐘绘煙閹规劦鍤欓柛姘秺閺屸€愁吋鎼粹€崇缂備胶濯崹鍫曞蓟閵娾晜鍋嗛柛灞剧☉椤忥拷
开发学院数据库MSSQL Server MySQL中文参考手册5(安装MySQL下) 阅读

MySQL中文参考手册5(安装MySQL下)

 2007-11-11 08:49:03 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄧ粯銇勯幒瀣仾闁靛洤瀚伴獮鍥敍濮f寧鎹囬弻鐔哥瑹閸喖顬堝銈庡亝缁挸鐣烽崡鐐嶆棃鍩€椤掑嫮宓佸┑鐘插绾句粙鏌涚仦鎹愬闁逞屽墰閹虫捇锝炲┑瀣╅柍杞拌兌閻ゅ懐绱撴担鍓插剱妞ゆ垶鐟╁畷銉р偓锝庡枟閻撴洘銇勯幇闈涗簼缂佽埖姘ㄧ槐鎾诲礃閳哄倻顦板┑顔硷工椤嘲鐣烽幒鎴旀瀻闁规惌鍘借ⅵ濠电姷鏁告慨顓㈠磻閹剧粯鈷戞い鎺嗗亾缂佸鏁婚獮鍡涙倷閸濆嫮顔愬┑鐑囩秵閸撴瑦淇婇懖鈺冪<闁归偊鍙庡▓婊堟煛鐏炵硶鍋撻幇浣告倯闁硅偐琛ラ埀顒冨皺閺佹牕鈹戦悙鏉戠仸闁圭ǹ鎽滅划鏃堟偨缁嬭锕傛煕閺囥劌鐏犻柛鎰ㄥ亾婵$偑鍊栭崝锕€顭块埀顒佺箾瀹€濠侀偗婵﹨娅g槐鎺懳熺拠鑼舵暱闂備胶枪濞寸兘寮拠宸殨濠电姵纰嶉弲鎻掝熆鐠虹尨宸ョ€规挸妫濆铏圭磼濡搫顫嶇紓浣风劍閹稿啿鐣烽幋锕€绠婚悹鍥у级瀹撳秴顪冮妶鍡樺鞍缂佸鍨剁粋宥夋倷椤掍礁寮垮┑鈽嗗灣閸樠勭妤e啯鍊垫慨妯煎亾鐎氾拷闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄥジ鏌熼惂鍝ョМ闁哄矉缍侀、姗€鎮欓幖顓燁棧闂備線娼уΛ娆戞暜閹烘缍栨繝闈涱儐閺呮煡鏌涘☉鍗炲妞ゃ儲鑹鹃埞鎴炲箠闁稿﹥顨嗛幈銊╂倻閽樺锛涘┑鐐村灍閹崇偤宕堕浣镐缓缂備礁顑嗙€笛囨倵椤掑嫭鈷戦柣鐔告緲閳锋梻绱掗鍛仸鐎规洘鍨块獮鍥偋閸垹骞嶇紓鍌氬€烽悞锕傛晪缂備焦銇嗛崶銊у帗閻熸粍绮撳畷婊堟晝閸屾氨鐓戦梺鍛婂姦閻撳牆岣块弽顓熺厱婵犻潧妫楅悵鏃傛喐閺傝法鏆﹂柟顖炲亰濡茬偓绻涚€电ǹ孝闁靛牏枪椤繘鎼圭憴鍕彴闂佽偐鈷堥崜娑㈩敊婢舵劖鈷戦柣鎾虫捣缁夎櫣绱掗悩宕囧⒌妤犵偛鍟妶锝夊礃閳轰讲鍋撴繝姘參婵☆垯璀﹀Σ濂告煙閼恒儲绀嬫慨濠冩そ濡啫鈽夋潏顭戔偓鍡樼節绾版ǚ鍋撻搹顐㈡灎閻庤娲忛崹浠嬪箖娴犲宸濆┑鐐靛亾鐎氬ジ姊洪懡銈呮瀾闁荤喆鍎抽埀顒佹皑閸忔ê鐣烽婵堢杸婵炴垶鐟ч崢閬嶆⒑缂佹◤顏嗗椤撶喐娅犻柣銏犳啞閻撳繘鏌涢埄鍐炬當闁逞屽墮濠€杈╃磽閹惧顩烽悗锝庝簻缁愭稒绻濋悽闈浶㈤悗姘煎墴閻涱噣宕奸妷锔规嫼缂佺虎鍘奸幊搴ㄋ夊澶嬬厵婵炶尪顔婄花鑺ヤ繆閸欏濮嶇€殿喗鎸抽幃銏ゅ传閸曘劌褰忛梻鍌氬€搁崐鎼佸磹妞嬪孩顐芥慨姗嗗厳缂傛氨鎲稿鍥у疾闂備線娼ч悧鍡椕洪悩璇茬;闁圭偓鍓氬ḿ鈺傘亜閹扳晛鐏╃紒渚囧櫍濮婅櫣绱掑Ο鍦箒闂侀潻缍囩紞渚€鎮伴鈧獮鎺楀箠閾忣偅顥堥柛鈹惧亾濡炪倖甯掗崐缁樼▔瀹ュ鐓ユ繝闈涙椤ョ姷绱掗埦鈧崑鎾绘⒒閸屾艾鈧悂鎮ф繝鍕煓闁硅揪绠戝Ч鍙夌箾閸℃璐╅柣鐔稿閸亪鏌涢鐘茬伄闁哄棭鍋婂娲传閸曨厾鍔圭紓鍌氱С閻掞箓骞堥妸鈺佺劦妞ゆ帒瀚悡鍐煙椤栨粌顣肩痪顓犲亾缁绘繈鍩€椤掍焦缍囬柕濞у懎楠勯梻浣告惈濞层劑宕伴幘璺哄К闁逞屽墮閳规垿顢欓弬銈勭返闂佸憡锕㈢粻鏍х暦閵忋倖鍋ㄩ柛娑樑堥幏铏圭磽閸屾瑧鍔嶉柨姘攽椤曞棛鐣甸柡灞剧洴楠炴﹢寮堕幋婵囨嚈闂備浇顕栭崰妤勬懌濠电偟鍘х换妯讳繆閹间礁围闁搞儮鏅濋弳浼存⒒閸屾瑧顦︽繝鈧潏鈺佸灊妞ゆ牗绮嶉弳婊堟煟閹邦剛鎽犳繛鍛У缁绘盯骞嬮悙瀵告缂佺偓宕橀崑鎰閹惧瓨濯撮悹鎰靛灣缁辨澘鈹戦悙鏉戠祷妞ゆ洦鍙冮崺鈧い鎺戝枤濞兼劖绻涢崣澶屽ⅹ闁伙絿鍏橀、妤呭礃椤忓啰鑳洪梻鍌氬€风粈渚€骞夐敓鐘茬闁哄洢鍨归悿顕€鏌eΟ娆惧殭缂佲偓閸喓绡€闂傚牊绋撴晶娑氣偓瑙勬礀瀵墎鎹㈠☉銏犵闁绘劑鍔庣槐浼存⒑閸濆嫭顥滄俊顐n殜閸╃偤骞嬮敂钘変汗闁哄鐗滈崑鍕储閿熺姵鈷戦弶鐐村閸斿秹鏌eΔ浣虹煂婵″弶鍔欓獮妯尖偓娑櫭鎾寸箾鐎电ǹ孝妞ゆ垵鎳橀獮妤呮偨閸涘ň鎷洪梺闈╁瘜閸樹粙宕甸埀顒€鈹戦悙鑼勾闁稿﹥绻堥獮鍐┿偅閸愨晛鈧鏌﹀Ο渚Ш妞ゆ柨锕铏规喆閸曨剙鍓归梺鍛娒肩划娆忕暦閹剧粯鍋ㄩ柛娑樑堥幏娲⒑閼姐倕鏋戞繝銏★耿楠炲啯绗熼埀顒勫蓟閿濆绠抽柣鎰暩閺嗐倝姊虹拠鈥虫灍妞ゃ劌锕悰顕€寮介妸锕€顎撻梺绋跨箰椤︽壆鈧俺妫勯埞鎴︽倷閼搁潧娑х紓浣瑰絻濞尖€崇暦閺囥垹围濠㈣泛锕ら幆鐐烘⒑闁偛鑻晶瀛樻叏婵犲啯銇濇鐐寸墵閹瑥霉鐎n亙澹曢梺鍝勭▉閸樹粙宕戠€n喗鐓熸俊顖氱仢閸氬湱鈧鎸风欢姘舵偂椤愶箑鐐婇柕濞р偓婵洭姊洪崫鍕櫤闁诡喖鍊垮濠氬Ω閳哄倸浜為梺绋挎湰缁嬫垿顢旈敓锟�婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄闁挎繂妫Λ鍕⒑閸濆嫷鍎庣紒鑸靛哺瀵鈽夊Ο閿嬵潔濠殿喗顨呴悧濠囧极妤e啯鈷戦柛娑橈功閹冲啰绱掔紒妯虹伌濠碉紕鏁诲畷鐔碱敍濮橀硸鍟嬮梻浣告啞椤ㄥ牓宕戦悢鍝ヮ浄闁兼祴鏅濈壕钘壝归敐鍛儓妞ゅ骸鐭傞弻娑㈠Ω閵壯冪厽閻庢鍠涢褔鍩ユ径鎰潊闁绘ḿ鏁搁弶鎼佹⒒閸屾艾鈧悂鎮ф繝鍕煓闁圭儤顨嗛崐鍫曟煕椤愮姴鍔滈柛濠勬暬閺岋綁鎮㈤崫鍕垫毉闂佸摜鍠撻崑鐔烘閹烘梹瀚氶柟缁樺笚濞堢粯绻濈喊澶岀?闁轰浇顕ч悾鐑芥偄绾拌鲸鏅┑顔斤耿绾悂宕€n喗鈷戦悹鍥ㄧ叀閸欏嫭绻涙担鍐叉搐缁犵儤绻濇繝鍌滃闁稿鏅涢埞鎴﹀磼濮橆厼鏆堥梺鎶芥敱閸ㄥ綊鎯€椤忓牜鏁囬柣鎰綑椤庢稑鈹戦悙鎻掓倯闁告梹鐗滈幑銏犫槈閵忊€虫濡炪倖宸婚崑鎾绘煛鐎n亜顒㈤柕鍥у椤㈡洟濮€閵忋埄鍞虹紓鍌欐祰妞村摜鏁幒鏇犱航闂備礁鍚嬬粊鎾疾濠婂牆鍚圭€光偓閸曨兘鎷绘繛鎾村焹閸嬫捇鏌嶈閸撴盯宕戝☉銏″殣妞ゆ牗绋掑▍鐘炽亜閺冨洤浜归柡鍡楁閺屻劌鈹戦崱娆忣暫闂佸憡鏌ㄩ悘姘跺Φ閸曨垱鏅滈柣锝呰嫰瀵劑姊虹拠鈥虫珯缂佺粯绻冩穱濠囨嚋闂堟稓绐為柣搴秵閸撴瑧鏁ィ鍐┾拻濞达絿枪椤ュ繘鏌涚€n亝鍣介柟骞垮灲瀹曟﹢顢欓懖鈺嬬幢婵$偑鍊曠换鎰板箠閹邦喚涓嶉柛鎾椻偓閸嬫捇鎮烽弶娆炬闂佸摜濮靛ú婊堟嚍鏉堛劎绡€婵﹩鍓涢悾楣冩⒑缂佹ɑ鐓ラ柛姘儔閸╂盯骞嬮敂钘夆偓鐢告煕閿旇骞栭弽锟犳⒑闂堟稒顥滈柛鐔告尦瀵濡舵径濠勵槰闂佽偐鈷堥崜娆撴偂閻斿吋鍊甸悷娆忓缁€鍐磼鐠囪尙澧︾€殿噮鍋婂畷姗€顢欓懖鈺佸Е婵$偑鍊栫敮鎺斺偓姘€鍥х劦妞ゆ帊鐒﹂ˉ鍫⑩偓瑙勬礃閿曘垽銆佸▎鎾冲簥濠㈣鍨板ú锕傛偂閺囥垺鐓冮柍杞扮閺嬨倖绻涢崼鐕傝€块柡宀嬬秮閹垻绮欓崹顕呮綒婵犳鍠栭敃銉ヮ渻娴犲绠栭柍鈺佸暞閸庣喖鏌嶉埡浣告殲闁伙讣缍佸缁樻媴閾忕懓绗¢梺缁橆殕濞茬喐淇婇崜浣虹煓閻犳亽鍔嶅▓楣冩⒑缂佹ê鐏﹀畝锝堟硶瀵囧焵椤掑嫭鈷戦柟鑲╁仜閸斺偓闂佸憡鍔戦崝搴ㄥΧ椤曗偓濮婂宕掑▎鎴犵崲濠电偘鍖犻崟鍨啍闂婎偄娲﹀ú姗€锝為弴銏$厸闁搞儯鍎遍悘鈺呮煕鐏炶濡介柕鍥у缁犳盯骞樼捄渚澑闂備焦濞婇弨閬嶅垂閸ф钃熼柣鏂垮悑閸ゅ啴鏌嶆潪鐗堫樂缂侇喖鐖煎娲川婵犲啠鎷瑰銈冨妼閿曨亜顕f繝姘櫢闁绘ɑ褰冪粣娑橆渻閵堝棙顥堥柡渚囧枟閹便劑宕堕埡鍐紳婵炶揪绲挎灙闁逞屽墮濠€閬嶅极椤曗偓閹垺淇婇幘铏窛闁逞屽墴濞佳囧箺濠婂懎顥氬┑鍌溓圭痪褔鏌涢锝団槈濠德ゅ亹缁辨帒螖娴d警鏆$紓浣虹帛閻╊垶骞冮埄鍐╁劅闁挎繂娴傞崯瀣⒒娴h櫣銆婇柡鍌欑窔瀹曟粌鈹戠€n亞顔嗛梺鍛婄☉閻°劑鎮¢妷鈺傚€甸柨婵嗘噽娴犳稓绱撳鍡╂疁婵﹤顭峰畷鎺戭潩椤戣棄浜剧€瑰嫭鍣磋ぐ鎺戠倞鐟滄粌霉閺嶎厽鐓忓┑鐐靛亾濞呭棝鏌涙繝鍌涘仴闁哄被鍔戝鎾倷濞村浜鹃柛婵勫劤娑撳秹鏌$仦璇插姕闁绘挻娲熼弻鏇熷緞濡儤鐏堟繝鈷€灞芥珝闁哄矉绱曢埀顒婄岛閺呮繄绮i弮鍫熺厸鐎光偓閳ь剟宕伴弽褏鏆︽繝濠傛-濡查箖鏌i姀鈺佺仭闁烩晩鍨跺濠氭晸閻樻彃绐涘銈嗘濡嫰鍩€椤掍礁濮嶉柡宀嬬磿娴狅妇鎷犻幓鎺濇綆闂備浇顕栭崰鎾诲磹濠靛棛鏆﹂柟鐑樺灍濡插牊鎱ㄥΔ鈧Λ鏃傛閿燂拷闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄧ粯銇勯幒瀣仾闁靛洤瀚伴獮鍥敍濮f寧鎹囬弻鐔哥瑹閸喖顬堝銈庡亝缁挸鐣烽崡鐐嶆棃鍩€椤掑嫮宓佸┑鐘插绾句粙鏌涚仦鎹愬闁逞屽墰閹虫捇锝炲┑瀣╅柍杞拌兌閻ゅ懐绱撴担鍓插剱妞ゆ垶鐟╁畷銉р偓锝庡枟閻撴洘銇勯幇闈涗簼缂佽埖姘ㄧ槐鎾诲礃閳哄倻顦板┑顔硷工椤嘲鐣烽幒鎴旀瀻闁规惌鍘借ⅵ濠电姷鏁告慨顓㈠磻閹剧粯鈷戞い鎺嗗亾缂佸鏁婚獮鍡涙倷閸濆嫮顔愬┑鐑囩秵閸撴瑦淇婇懖鈺冪<闁归偊鍙庡▓婊堟煛鐏炵硶鍋撻幇浣告倯闁硅偐琛ラ埀顒冨皺閺佹牕鈹戦悙鏉戠仸闁圭ǹ鎽滅划鏃堟偨缁嬭锕傛煕閺囥劌鐏犻柛鎰ㄥ亾婵$偑鍊栭崝锕€顭块埀顒佺箾瀹€濠侀偗婵﹨娅g槐鎺懳熺拠鑼舵暱闂備胶枪濞寸兘寮拠宸殨濠电姵纰嶉弲鎻掝熆鐠虹尨宸ョ€规挸妫濆铏圭磼濡搫顫嶇紓浣风劍閹稿啿鐣烽幋锕€绠婚悹鍥у级瀹撳秴顪冮妶鍡樺鞍缂佸鍨剁粋宥夋倷椤掍礁寮垮┑鈽嗗灣閸樠勭妤e啯鍊垫慨妯煎亾鐎氾拷  闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鏁愭径濠勵吅闂佹寧绻傞幉娑㈠箻缂佹ḿ鍘遍梺闈涚墕閹冲酣顢旈銏$厸閻忕偠顕ч埀顒佺箓閻g兘顢曢敃鈧敮闂佹寧妫佹慨銈夋儊鎼粹檧鏀介柣鎰▕閸ょ喎鈹戦鈧ḿ褔锝炲┑瀣╃憸搴綖閺囥垺鐓欓柟瑙勫姦閸ゆ瑧鐥幆褍鎮戠紒缁樼洴瀹曞崬螣閾忓湱鎳嗛梻浣告啞閿曨偆妲愰弴鐘愁潟闁规儳顕悷褰掓煕閵夋垵瀚ぐ顖炴⒒娴h鍋犻柛鏂跨焸閹儵宕楅梻瀵哥畾闂佸湱铏庨崰鏍矆閸愨斂浜滈柡鍐ㄥ€哥敮鍓佺磼閹邦厾娲存慨濠冩そ瀹曨偊宕熼崹顐嵮囨⒑閹肩偛濡肩紓宥咃工閻g兘濮€閻樺棙妞介、鏃堝川椤撴稑浜鹃柛顭戝亽濞堜粙鏌i幇顖氱毢濞寸姰鍨介弻娑㈠籍閳ь剛鍠婂澶娢﹂柛鏇ㄥ灡閺呮粓鎮归崶顏勭毢濞寸姵鎮傞幃妤冩喆閸曨剛鈹涚紓浣虹帛缁诲牓鎮伴鑺ュ劅闁靛⿵绠戝▓鐔兼⒑闂堟冻绱¢柛鎰╁妼椤╊剟姊婚崒姘偓鎼併偑閹绢喖纾婚柛鏇ㄥ€嬪ú顏呮櫇闁逞屽墰閸欏懘姊洪崫鍕犻柛鏂垮閺呭爼鏁撻悩鏂ユ嫽闂佺ǹ鏈悷锔剧矈閻楀牄浜滈柡鍥ф閹冲宕戦幘璇插瀭妞ゆ劑鍨虹拠鐐烘倵鐟欏嫭绀冪紒顔芥崌楠炲啴濮€閿涘嫰妾繝銏f硾椤戝洨绮欐笟鈧缁樻媴閻熸澘濮㈢紓浣虹帛閸旀洟鏁冮姀鈩冪秶闁宠桨绶″Λ婊堟⒑缁嬭法绠绘俊顐ユ硶閹广垽宕卞Ο闀愮盎闂佸搫绉查崝搴ㄣ€傞弻銉︾厵妞ゆ牗姘ㄦ晶娑㈡煏閸パ冾伃妞ゃ垺娲熸慨鈧柕蹇嬪灩婵鲸绻濆▓鍨灈闁挎洏鍎遍—鍐寠婢跺本娈鹃梺缁樺灩閻℃棃寮崶銊х闁瑰鍋熼幊鍐煟濠靛鎲炬慨濠勭帛閹峰懘宕ㄩ棃娑氱Ш妞ゃ垺鐗犲畷銊╊敇閸ャ劎鈽夐柍瑙勫灩閳ь剨缍嗘禍鐐烘偩妤e啯鈷戦梺顐ゅ仜閼活垱鏅堕鐐寸厪闁搞儜鍐句紓缂備胶濮甸惄顖炵嵁濡皷鍋撻崹顐e仩闁稿鍔栫换婵堝枈濡椿娼戦梺鎼炲妽婢瑰棝鍩€椤掍胶顣叉繝銏★耿閿濈偠绠涢幘浣规そ椤㈡棃宕熼鍡欏€為梻鍌欑閹测€趁洪敃鍌氱婵ǹ娉涚粻顖炴煕濡ゅ啫浜归柡鈧禒瀣厽闁归偊鍘肩徊鑽ょ磼閻欐瑥鍟伴弳鍡涙煥濠靛棙鍣洪柛瀣ㄥ劜椤ㄣ儵鎮欓弶鎴犱紝婵犳鍠掗崑鎾绘⒑缂佹﹫渚涢柛瀣嚇瀵剟鍩€椤掆偓閳规垿鎮╅崹顐f瘎婵犳鍠栭顓㈠焵椤掍礁鍤柛锝忕到椤曪綁宕奸弴鐐殿啇婵炶揪绲介崢婊堝箯濞差亝鈷戦柛娑橈功缁犳捇鎮楀鐓庡箹妞ゆ柨绻愰埞鎴﹀幢韫囨梹鏉告俊鐐€栧褰掑磿閹惰棄鍌ㄩ柟缁㈠枟閻撴瑦銇勯弮鍥跺殭鐎规挸妫楅埞鎴︽晬閸曨偄骞嬮梺绯曟櫔缁绘繂鐣烽幒鎳虫梹鎷呴崜韫床婵犵數濮烽弫鎼佸磻閻樿绠垫い蹇撴缁躲倕霉閻樺樊鍎忕紒鐘侯潐閵囧嫰骞囬埡浣插亾閺嶎厼姹叉繝濠傜墛閸嬶綁寮堕悙鏉戭€滄い鎺斿枛閺岋綁寮幐搴&闂佸搫鐭夌紞渚€骞冮姀鐘垫殝闁规鍠氬▔鍧楁⒒娴e鈧偓闁稿鎹囬弻銈嗘叏閹邦兘鍋撳Δ鍐棜濠靛倸鎲¢悡鏇㈡倶閻愰潧浜鹃柣銊﹀灩閳ь剚绋掔换鍌濈亙濠德板€曢敃锝囪姳閻戣姤鐓曟俊銈傚亾闁哥喎娼¢幃楣冩倻閼恒儱浜楅柟鍏兼儗閸犳宕撻悽鍛娾拺闁圭ǹ娴风粻鎾绘煙閸愯尙校缂佹梻鍠栧鎾閳锯偓閹锋椽姊洪崨濠勭畵閻庢凹鍓熷鍐测枎閹惧鍘藉┑掳鍊愰崑鎾翠繆椤愶絿銆掗柛鎺撳浮瀹曞ジ濡烽妷褜妲伴梻浣哥-閹虫捇濡靛Ο鑹板С濠电姵纰嶉ˉ濠冦亜閹扳晛鐏柟鍏煎姈缁绘稓鈧數枪閸樻挳鎸婂┑瀣叆闁哄洦顨呮禍楣冩⒒閸パ屾Ч缂佺粯绻冪换婵嬪磼濠婂啠鍙¢梻浣风串缁叉儳顪冩禒瀣摕闁挎稑瀚▽顏堟偣閸ャ劌绲绘い顒€鐗撳铏光偓鍦濞兼劙鏌涢妸銉т虎闁伙絿鍏樺畷锟犳倷閳哄偆娼旈梻浣烘嚀閸氣偓缂佲偓娴e湱顩查柣鎰靛厸缁诲棝鏌曢崼婵嗏偓鍛婄閹屾富闁靛牆楠稿銊╂煕鎼粹槅鐓肩弧鎾炽€掑锝呬壕闂佸搫鏈惄顖炲箖閳轰胶鏆﹂柛銉戔偓閹风増绻濋悽闈浶涢柛瀣尭閵嗘帒顫濋敐鍛婵犳鍠栭敃銊モ枍閿濆洦顫曢柟鐑樺殾閻旂厧鍗抽柣鏃堫棑娴煎矂姊虹拠鈥虫灓闁稿繑蓱娣囧﹪鎮块锝喰ラ梻浣呵归鍡涘箰閹间緤缍栨繝闈涱儐閸嬪倿骞栧ǎ顒€鐏ù婊冨⒔缁辨捇宕掑▎鎴g獥闂佸摜濮靛銊╁礆閹烘鏁嶉柣鎰棘瑜旈弻銊モ攽閸♀晜笑缂備讲鍋撻柛鎰靛枟閻撳啴鏌涘┑鍡楊仼闁哄棙鐟﹂〃銉╂倷閼碱剙顤€婵烇絽娲ら敃顏堝箖濞嗘搩鏁傞柛鏇樺妼娴滈箖鏌″搴″箹缂佲偓婢舵劖鐓欓弶鍫濆⒔閻h京鐥幆褏绉洪柡宀嬬節瀹曞爼濡烽妷褌鎮i梻浣告啞閸ㄨ绻涢埀顒侇殽閻愬澧懣鎰亜閹哄棗浜炬繝纰樷偓鑼煓闁哄矉缍侀獮妯兼崉閻戞ḿ浜梻浣虹帛閹尖晠宕戞繝鍌滄殾闁诡垶鍋婂銊╂⒑缁嬪潡顎楃紒缁橈耿瀵鈽夐姀鐘电潉闂侀€炲苯澧伴柛鎺撳浮楠炴ḿ鎷犻懠鑸垫啺闂備礁鎼ú銏ゅ垂瑜版帗鍊峰┑鐘插閸犳劗鈧箍鍎遍ˇ浠嬪极閸屾稏浜滈柟鎹愭硾琚ラ梺绋款儐閹告悂鍩㈤幘璇插瀭妞ゆ梻鏅禍鑸电節閻㈤潧浠滈柛姘儔閹兘濡搁埡鍌氣偓鍫曟煙閻戞﹩娈曢柍閿嬪灴閺屾稑鈽夊鍫濆缂備胶濮甸幑鍥箖濡も偓椤繈鎮℃惔鈾€鎷ゆ俊鐐€戦崐鏇㈠磹閸︻厽宕叉繝闈涚墕閺嬪牆顭跨捄铏圭伇闁挎稓鍠栧铏圭矙濞嗘儳鍓遍梺鎼炲妼閻忔繈鎮鹃悜钘夌疀闁哄娉曢娲⒑閹稿孩纾甸柛瀣崌閺屾盯濡搁妷銉㈠亾閸︻厽宕叉繛鎴烇供閸熷懏銇勯弮鍥у惞闁告垵缍婂铏圭矙濞嗘儳鍔€缂備胶绮换鍫濐嚕鐠囧樊鍚嬪璺猴梗缁卞爼姊洪崨濠冨闁告挻鐟ラ埢宥夋晲閸モ晝锛濇繛杈剧到閹碱偅鐗庨梻浣虹帛椤ㄥ牊绻涢埀顒傗偓娈垮枦椤曆囶敇閸忕厧绶炲┑鐘插楠炴劕鈹戦悙鑸靛涧缂佽弓绮欓獮澶愬灳閺傘儲鐏侀梺鍝勮閸庢煡鍩涢幋鐘电<閻庯綆鍋勯婊堟煙閻у摜绉柡灞剧洴閹晛鐣烽崶褉鎷伴柣搴㈩問閸犳牠鈥﹀畡閭﹀殨闁圭虎鍠栭~鍛存煟濮椻偓濞佳囧焵椤掑倸浠遍柟顔煎槻楗即宕橀顖樺€濋弻銈嗐偊閸ф鎽电紓浣虹帛缁诲倿锝炲┑瀣垫晣闁绘ɑ褰冪粻銉╂⒒閸屾瑧顦﹂柟璇х節瀹曞綊顢涢悙鑼紮闂佸搫绋侀崑鈧柛瀣尭椤繈鎮欓鈧锟�
核心提示:4.12 Win32 注意事项这节描述在Win32上安装和使用MySQL(和PHP搭配之最佳组合),这也在MySQL(和PHP搭配之最佳组合) Win32分发所带的“readme”文件中描述,MySQL中文参考手册5(安装MySQL下), 4.12.1 在Win32上安装MySQL(和PHP搭配之最佳组合)如果你没有一
4.12 Win32 注意事项
这节描述在Win32上安装和使用MySQL(和PHP搭配之最佳组合),这也在MySQL(和PHP搭配之最佳组合) Win32分发所带的“readme”文件中描述。 

4.12.1 在Win32上安装MySQL(和PHP搭配之最佳组合)
如果你没有一个注册的MySQL(和PHP搭配之最佳组合)版本,你应该首先下载共享软件版本,从: 

sql.com/news/article-22.html">MySQL(和PHP搭配之最佳组合) 3.21.29 

如果你准备从一些其他程序连接MySQL(和PHP搭配之最佳组合),你也可能需要MyODBC驱动程序。你可在MySQL(和PHP搭配之最佳组合)下载页找到。 

安装任何一个分发,在某个空目录解压缩它并且运行Setup.exe程序。 

缺省地,MySQL(和PHP搭配之最佳组合)-Win32被配置安装在“C:MySQL(和PHP搭配之最佳组合)”。如果你想要在其它地方安装MySQL(和PHP搭配之最佳组合),在“C:MySQL(和PHP搭配之最佳组合)”安装它,然后将安装移到你想要的地方。如果你真的移走MySQL(和PHP搭配之最佳组合),你必须通过提供选项给MySQL(和PHP搭配之最佳组合)d告诉MySQL(和PHP搭配之最佳组合)d那里的所有一切,使用C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d --help显示所有的选项目!例如,如果你移动MySQL(和PHP搭配之最佳组合)分发到“D:programsMySQL(和PHP搭配之最佳组合)”,你必须用D:programsMySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d --basedir D:programsMySQL(和PHP搭配之最佳组合)来启动MySQL(和PHP搭配之最佳组合)d。

用登记的MySQL(和PHP搭配之最佳组合)版本,你也可以创建一个“C:my.cnf”文件来保存用于MySQL(和PHP搭配之最佳组合)服务器的任何缺省选项。拷贝文件“MySQL(和PHP搭配之最佳组合)my-example.cnf”到“C:my.cnf”并且编辑它来适用于你的安装。注意你应该用"/"而不是""指定所有的路径。如果你使用“”,你需要指定两次(“”),因为在MySQL(和PHP搭配之最佳组合)中“”是转义字符,见4.15.4 选项文件。 

4.12.2 在Win95/Win98上启动MySQL(和PHP搭配之最佳组合)
MySQL(和PHP搭配之最佳组合)使用 TCP/IP 把一个客户连接到一个服务器。(这将允许在你的网络上任何机器连接你的MySQL(和PHP搭配之最佳组合)服务器)。因此,你必须在启动MySQL(和PHP搭配之最佳组合)前在你的机器上安装TCP/IP,你可以在你的Windows CDROM上找到TCP/IP 。 

注意:如果你正在使用一个旧的Win95版本(例如OSR2),很有可能你有一个老的Winsock包!MySQL(和PHP搭配之最佳组合)需要Winsock 2!你可从微软得到最新的Winsock。Win98有新的Winsock 2库作为缺省,这样上述不适用于Win98。 

你能使用2个不同的MySQL(和PHP搭配之最佳组合)服务器: 

MySQL(和PHP搭配之最佳组合)d 用完整调试和自动存储器分配检查编译 
MySQL(和PHP搭配之最佳组合)d-opt 对Pentium 处理器优化。 

上面两个应该在任何 > = i386的Intel处理器上工作 。 

为了启动MySQL(和PHP搭配之最佳组合)d服务器,你应该启动一个MSDOS窗口并键入: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d
这将在一个没有窗口的背景启动MySQL(和PHP搭配之最佳组合)d。 

你可以这样杀死MySQL(和PHP搭配之最佳组合)服务器,执行: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)admin -u root shutdown
注意Win95/Win98不支持命名管道的创建。在Win95/Win98上,你只能使用命名管道连接运行在一个NT服务器上的远程MySQL(和PHP搭配之最佳组合)。 

4.12.3 在NT上启动MySQL(和PHP搭配之最佳组合)
Win95/Win98小节也适用于在NT上的MySQL(和PHP搭配之最佳组合),有下列差别: 

为了是MySQL(和PHP搭配之最佳组合)用TCP/IP工作,你必须安装服务包3(service pack 3)(或更新)! 

对于NT,服务器名字是MySQL(和PHP搭配之最佳组合)d-nt。通常你应该在 NT 上安装MySQL(和PHP搭配之最佳组合)作为一种服务: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d-nt --install
(你可以在 NT 上使用MySQL(和PHP搭配之最佳组合)d或MySQL(和PHP搭配之最佳组合)d-opt服务器,但是那些不能作为一种服务启动或使用命名管道。)

你可以用下列命令启动和停止MySQL(和PHP搭配之最佳组合)服务: 

NET START MySQL(和PHP搭配之最佳组合)
NET STOP MySQL(和PHP搭配之最佳组合)

注意在这种情况下,你不能对MySQL(和PHP搭配之最佳组合)d-nt使用任何其他选项! 

如果你需要用任何选项启动MySQL(和PHP搭配之最佳组合)d-nt,你也可以作为在NT上的一个独立程序运行MySQL(和PHP搭配之最佳组合)d-nt!如果你在NT上没有选项启动MySQL(和PHP搭配之最佳组合)d-nt,MySQL(和PHP搭配之最佳组合)d-nt尝试启动自己作为一种有默认选项的服务。如果你停止了MySQL(和PHP搭配之最佳组合)d-nt,你必须用NET START MySQL(和PHP搭配之最佳组合)启动它。

服务用MySQL(和PHP搭配之最佳组合)名字被安装,一旦安装,它必须使用服务控制管理器(SCM)实用程序启动服务(在控制面板中找到)或使用NET START MySQL(和PHP搭配之最佳组合)命令。如果需要任何选项,在你启动MySQL(和PHP搭配之最佳组合)服务前必须作为SCM实用程序的“启动参数”指定它们。一旦运行,可使用MySQL(和PHP搭配之最佳组合)admin或从SCM实用程序或使用命令NET STOP MySQL(和PHP搭配之最佳组合)停止MySQL(和PHP搭配之最佳组合)d-nt。如果你使用SCM停止MySQL(和PHP搭配之最佳组合)d-nt,SCM有一条关于MySQL(和PHP搭配之最佳组合)d shutdown normally奇怪的消息,当作为一种服务运行时,MySQL(和PHP搭配之最佳组合)d-nt没有控制台的存取权限,所以没有消息可以看见。 

在NT上你可以得到下列服务错误消息: 

Permission Denied (权限拒绝) 意味着它不能找到MySQL(和PHP搭配之最佳组合)d-nt.exe 
Cannot Register (不能登记) 意味着路径是不正确的 

如果你作为一种服务安装MySQL(和PHP搭配之最佳组合)d-nt有问题,尝试用完整的路径启动它: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d --install
如果这还不工作,你能通过在注册表修正路径使得MySQL(和PHP搭配之最佳组合)d-nt正确启动! 

如果你不想作为一种服务启动MySQL(和PHP搭配之最佳组合)d-nt,你可以如下启动它: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d-nt --standalone


C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)d-nt --standalone --debug
最新的版本在“C:MySQL(和PHP搭配之最佳组合)d.trace”给你一个调试踪迹。 

4.12.4 在 Win32 上运行 MySQL(和PHP搭配之最佳组合)
MySQL(和PHP搭配之最佳组合)在所有Win32平台上支持TCP/IP和NT上命名管道。如果客户安装了TCP/IP,缺省是对NT上的本地连接使用命名管道而对所有其他情形使用TCP/IP,主机名指定使用哪个协议: 

主机名 协议 
空 (没有) 在NT上,首先尝试命名管道;如果它不工作,使用TCP/IP。在Win95/Win98上,使用TCP/IP。 
. 命名管道 
localhost TCP/IP到当前主机 
主机名 TCP/IP 

通过指定命名管道--pipe选项,你可以强制一个MySQL(和PHP搭配之最佳组合)客户使用命名管道。使用--socket选项指定管道的名字。 

通过执行下列命令,你能测试MySQL(和PHP搭配之最佳组合)是否正在工作: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)show
C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)show -u root MySQL(和PHP搭配之最佳组合)
C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)admin version status proc
C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合) test

如果在Win95/Win98上MySQL(和PHP搭配之最佳组合)d很慢地回答连接,可能你的DNS有问题。在这种情况中下,用--skip-name-resolve启动MySQL(和PHP搭配之最佳组合)d并且在MySQL(和PHP搭配之最佳组合)授权表中仅使用localhost和IP数字。在你连接运行在NT上一个MySQL(和PHP搭配之最佳组合)d-nt的MySQL(和PHP搭配之最佳组合)服务器时,使用--pipe指定命名管道使用的参数,你也能避开DNS,对大多数MySQL(和PHP搭配之最佳组合)客户是可行的。 

有2个版本的MySQL(和PHP搭配之最佳组合)命令行工具: 

MySQL(和PHP搭配之最佳组合) 用原生Win32编译,它提供很有有限的文本编辑能力。 
MySQL(和PHP搭配之最佳组合)c 用Cygnus GNU 编译器和库编译,它提供readline编辑。 

如果你想使用MySQL(和PHP搭配之最佳组合)c.exe,你必须拷贝“C:MySQL(和PHP搭配之最佳组合)libcygwinb19.dll”到“windowssystem”(或类似的地方)。 

在Win32上缺省的权限给所有本地用户以所有数据库的完全权限。为了使MySQL(和PHP搭配之最佳组合)更安全,你应该为每个用户设置口令并删除MySQL(和PHP搭配之最佳组合).user中有Host='localhost'和User='的行。 

你也应该为root用户增加一个口令:(下列例子通过删除匿名用户,允许任何人存取“测试”数据库)

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合) MySQL(和PHP搭配之最佳组合)
MySQL(和PHP搭配之最佳组合)> DELETE FROM user WHERE Host='localhost' AND User=';
MySQL(和PHP搭配之最佳组合)> QUIT
C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)admin reload
C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)admin -u root password your_password

在你设置了口令以后,如果你想要关掉MySQL(和PHP搭配之最佳组合)d服务器, 你能使用这个命令做到: 

MySQL(和PHP搭配之最佳组合)admin -- user=root -- password=your_password shutdown
如果你正在使用在windows下的MySQL(和PHP搭配之最佳组合)共享软件版本,上面的命令将以 parse error near 'SET OPTION password'的错误而失败,这是因为,这是共享软件版本,它基于MySQL(和PHP搭配之最佳组合) 3.21,没有SET PASSWORD命令。 

对共享软件版本,你能如下设置root用户口令: 

C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合) MySQL(和PHP搭配之最佳组合)
MySQL(和PHP搭配之最佳组合)> UPDATE user SET password=PASSWORD('your password') WHERE user='root';
MySQL(和PHP搭配之最佳组合)> QUIT
C:MySQL(和PHP搭配之最佳组合)inMySQL(和PHP搭配之最佳组合)admin reload

有注册的MySQL(和PHP搭配之最佳组合)版本,你能很容易地用GRANT和REVOKE命令增加新用户和更改权限,见7.26 GRANT和REVOKE句法。对Windows 的共享软件版本,必须使用INSERT、UPDATE和DELETE在MySQL(和PHP搭配之最佳组合)数据库中的一个表来管理用户和他们的权限,见6.13 存取拒绝(Access denied)的错误原因。 

4.12.5 用SSH从Win32连接一个远程MySQL(和PHP搭配之最佳组合)
这是一个关于怎样用SSH 得到一个安全的连接远程MySQL(和PHP搭配之最佳组合)服务器的注意事项(David Carlson)。 

     
  • 在你的windows机器上安装SSH客户 - 我使用了一个来自http://www.doc.ic.ac.uk/~ci2/ssh/的免费SSH客户。其他有用的链接:http://www.npaci.edu/Security/npaci_security_software.html和http://www.npaci.edu/Security/samples/ssh32_windows/index.html. 
     
     
  • 启动SSH。设置主机名字 = 你的MySQL(和PHP搭配之最佳组合)服务器名或IP地址,设置userid=你的用户名登录到你的服务器。
     
  • 点击“local forwords”。设定local port: 3306, host: localhost, remote port: 3306
     
  • 保存一切,否则下次你将必须再做一遍。 
     
  • 用SSH登录到你的服务器。 
     
  • 启动一些ODBC应用程序(例如Access)。
     
  • 创造一个新文件并且用ODBC驱动程序链接到MySQL(和PHP搭配之最佳组合),就像你通常做的一样,除了对服务器用用户“localhost”。 
     


搞定。它对一个直接的因特网连接工作得很好。我有些问题,SSH与我的Win95网络和Wingate有冲突 - 但是那将是张贴在其他软件公司的用户组的话题! 

4.12.6 MySQL(和PHP搭配之最佳组合)-Win32与Unix MySQL(和PHP搭配之最佳组合)比较
MySQL(和PHP搭配之最佳组合)- Win32现在已经证明了自己很稳定。这个版本得MySQL(和PHP搭配之最佳组合)有与对应的Unix版本同样的特征,除了下面: 

Win95和线程 
Win95 为每个线程的创建损失大约200个字节的内存。因此,如果你进行许多连接,你不应该在Win95运行MySQL(和PHP搭配之最佳组合)d很长时间,因为MySQL(和PHP搭配之最佳组合)的每个连接都创建一个新线程!WinNT和Win98不能容忍这个bug。 
阻塞式读(blocking read) 
MySQL(和PHP搭配之最佳组合)为每个连接使用一个阻塞式读取,这意味着: 
一个连接将不在8个小时后自动被断开,就像MySQL(和PHP搭配之最佳组合)的Unix版本所发生的。 
如果一个连接“挂起”,不杀死MySQL(和PHP搭配之最佳组合)就不可能打破它。 
MySQL(和PHP搭配之最佳组合)admin kill在一个睡眠的连接上将不工作。 
只要有睡眠的连接,MySQL(和PHP搭配之最佳组合)admin shutdown不能中途中断。 
我们计划在不久的将来修正它。 

UDF函数 
暂时MySQL(和PHP搭配之最佳组合)-Win32不支持用户可定义函数。 
DROP DATABASE 
你不能抛弃一个正在被某些线程使用的数据库。 
从任务管理器杀死MySQL(和PHP搭配之最佳组合) 
在Windows95上,你不能从任务管理器或用shutdown实用程序杀死MySQL(和PHP搭配之最佳组合)。你必须用MySQL(和PHP搭配之最佳组合)admin shutdown关闭它。 
大小写区分的名字 
文件名在Win32上是忽略大小写的,因此Win32上的MySQL(和PHP搭配之最佳组合)数据库和表的名字也是忽略大小写的。唯一的限制是数据库和表的名字必须在整个一个给定的语句中大小写是一样的,因为它用my_table和MY_TABLE都指向同一个表子,下列查询将不工作: 
SELECT * FROM my_table WHERE MY_TABLE.col=1; 

“ ”目录字符 
在Win95上的路径名组成由“”字符分隔,它在MySQL(和PHP搭配之最佳组合)中也是转义字符。如果你正在使用LOAD DATA INFILE或SELECT ... INTO OUTFILE,你必须用两个“”字符或使用Unix风格的文件名“/”字符: 
LOAD DATA INFILE "C: mpskr.txt" INTO TABLE skr;
SELECT * FROM skr INTO OUTFILE 'C:/tmp/skr.txt';

Can't open named pipe错误 
如果你使用NT上的MySQL(和PHP搭配之最佳组合)-Win32共享软件版本,用最新的MySQL(和PHP搭配之最佳组合)客户,你将得到下列错误: 
error 2017: can't open named pipe to host: . pipe...

这是因为NT上MySQL(和PHP搭配之最佳组合)正式版本缺省地使用命名管道。你能通过为新MySQL(和PHP搭配之最佳组合)客户使用--host=localhost选项或创建一个包含下列信息的文件“C:my.cnf”来避免这个错误: 

[client]
host = localhost

Access denied for user错误 
在访问在同一机器上的一个MySQL(和PHP搭配之最佳组合)服务器时,如果你得到Access denied for user: 'some-user@unknown' to database 'MySQL(和PHP搭配之最佳组合)'的错误,这意味着MySQL(和PHP搭配之最佳组合)不能正确解释你的主机名。为了修正它,你应该创建一个文件“windowshosts”,有下列信息: 
127.0.0.1 localhost
对于可能想要帮助我们做好Win32版本的任何人,这里有的一些开放的问题: 

制作一个单用户MySQL(和PHP搭配之最佳组合).DLL服务器。这应该包括一个标准MySQL(和PHP搭配之最佳组合)服务器的一切,除了线程创建外。这将使MySQL(和PHP搭配之最佳组合)在不需要一个真正的客户机/服务器和不需要从其他主机存取服务器的应用程序时更容易使用。 
为MySQL(和PHP搭配之最佳组合)安装增加一些漂亮的“start”和“shutdown”图标。 
为MySQL(和PHP搭配之最佳组合)启动选项创建造一个工具管理注册表条目。注册表条目的度缺已经被编码进MySQL(和PHP搭配之最佳组合)d.cc,但是它应该重新编码而更加面向“参数”,该工具应该也能更新“ my.cnf”文件,如果用户比较喜欢使用它而不是注册表。 
当用--install登记MySQL(和PHP搭配之最佳组合)d作为一种服务(在 NT 上 )时,如果你也可以在命令行上增加缺省选项,它将更好,目前解决办法是更新“C:my.cnf”文件。 
当你挂起一个运行Win95的膝上计算机时,当膝上计算机被恢复时,MySQL(和PHP搭配之最佳组合)d守护程序不接受新连接。我们不知道这是否 Win95、TCP/IP或MySQL(和PHP搭配之最佳组合)的问题。 
能从任务管理器杀死MySQL(和PHP搭配之最佳组合)d将绝对是好事,目前,你必须使用MySQL(和PHP搭配之最佳组合)admin shutdown。 
移植用在 MySQL(和PHP搭配之最佳组合)命令行工具的readline到Win32。 
标准的GUI版本MySQL(和PHP搭配之最佳组合)客户(MySQL(和PHP搭配之最佳组合)、MySQL(和PHP搭配之最佳组合)show、MySQL(和PHP搭配之最佳组合)admin和MySQL(和PHP搭配之最佳组合)dump) 将更好。 
如果在“net.c”中的套接字“读”和“写”函数是可中断的,那将更好。这将有可能在Win32上用MySQL(和PHP搭配之最佳组合)admin kill杀死打开的线程。 
制作有关哪些Windows程序能工作在MySQL(和PHP搭配之最佳组合)-Win32/MyODBC和必须做什么在能让他们工作的文档。 
MySQL(和PHP搭配之最佳组合)d总是在“C”处启动而不在缺省地点,我们想让MySQL(和PHP搭配之最佳组合)d使用当前地点用于排序顺序。 
移植sqlclient到Win32(几乎完成)并加入更多的特征! 
把更多的选项加到MySQL(和PHP搭配之最佳组合) Manager。 
在服务器和客户之间改变通讯协议,使用Windows内部通讯而不是套接字和TCP/IP。 
用.DLL实现UDF函数。 
增加宏以使用由Win32提供的更快的对线程安全的增加/减少方法。 
其他Win32特定问题在MySQL(和PHP搭配之最佳组合)-Win32分发的“README”文件中描述。 

4.13 OS/2 注意事项
MySQL(和PHP搭配之最佳组合)使用太多的打开文件。因此,你应该增加类似下面的东西到你的“CONFIG.SYS”文件: 

SET EMXOPT=-c -n -h1024 
如果你不这样做,你将可能碰到下列错误: 

File 'xxxx' not found (Errcode: 24) 
当OS/2 Warp 3上使用MySQL(和PHP搭配之最佳组合)时,要求FixPack 29或以上。用OS/2 Wrap 4,要求FixPack 4或以上。这是Pthreads库的一个要求。MySQL(和PHP搭配之最佳组合)必须安装在支持长文件名的一个分区上,如HPFS、FAT32等等。 

“INSTALL.CMD”脚本必须从OS/2'自己的“CMD.EXE”运行并且不能工作在替代品如“4OS2.EXE”。 

“scripts/MySQL(和PHP搭配之最佳组合)-install-db”脚本已经被重新命名了:它现在调用“install.cmd”并且是一个 REXX 手迹,将安装缺省的MySQL(和PHP搭配之最佳组合)安全配置并为MySQL(和PHP搭配之最佳组合)创建WorkPlace Shell 图标。 

动态模块支持通过编译但没有充分测试,动态模块应该使用Pthreads运行时刻库编译。 

gcc -Zdll -Zmt -Zcrtdll=pthrdrtl -I../include -I../regex -I.. 
  -o example udf_example.cc -L../lib -lMySQL(和PHP搭配之最佳组合)client udf_example.def
mv example.dll example.udf

注意:由于OS/2的限制,UDF模块名字的词干不能超过8个字符。模块被存储在“/MySQL(和PHP搭配之最佳组合)2/udf”目录;safe-MySQL(和PHP搭配之最佳组合)d.cmd脚本将把这个目录放在BEGINLIBPATH环境变量中。当使用UDF模块时,指定的扩展名被忽略--它被假定为“.udf”。例如,在 Unix上,共享模块可能被命名为“example.so”并且你可以象这样从它装载函数: 

CREATE FUNCTION metaphon RETURNS STRING SONAME "example.so";

正是OS/2,模块将被命名为“example.udf”,但是你不指定模块扩展名: 
CREATE FUNCTION metaphon RETURNS STRING SONAME "example"; 
4.14 TcX二进制代码
作为一种服务,TcX提供一套MySQL(和PHP搭配之最佳组合)的二进制分发,它在TcX或在客户友好地给与我们访问他们机器的权限的站点上被编译。 

这些分发用scripts/make_binary_distribution生成并且用下列编译器和选项配置: 

SunOS 4.1.4 2 sun4c with gcc 2.7.2.1 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) --disable-shared 
SunOS 5.5.1 sun4u with egcs 1.0.3a 
CC=gcc CFLAGS="-O6 -fomit-frame-pointer" CXX=gcc CXXFLAGS="-O6 -fomit-frame-pointer -felide-constructors -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) --with-low-memory 
SunOS 5.6 sun4u with egcs 2.90.27 
CC=gcc CFLAGS="-O6 -fomit-frame-pointer" CXX=gcc CXXFLAGS="-O6 -fomit-frame-pointer -felide-constructors -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) --with-low-memory 
SunOS 5.6 i86pc with gcc 2.8.1 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) --with-low-memory 
Linux 2.0.33 i386 with pgcc 2.90.29 (egcs 1.0.3a) 
CFLAGS="-O6 -mpentium -mstack-align-double -fomit-frame-pointer" CXX=gcc CXXFLAGS="-O6 -mpentium -mstack-align-double -fomit-frame-pointer -felide-constructors -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) --enable-assembler --with-MySQL(和PHP搭配之最佳组合)d-ldflags=-all-static 
SCO 3.2v5.0.4 i386 with gcc 2.7-95q4 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) 
AIX 2 4 with gcc 2.7.2.2 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) 
OSF1 V4.0 564 alpha with gcc 2.8.1 
CC=gcc CFLAGS=-O CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) --with-low-memory 
Irix 6.3 IP32 with gcc 2.8.0 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) 
BSDI BSD/OS 3.1 i386 with gcc 2.7.2.1 
CC=gcc CXX=gcc CXXFLAGS=-O ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) 
BSDI BSD/OS 2.1 i386 with gcc 2.7.2 
CC=gcc CXX=gcc CXXFLAGS=-O3 ./configure --prefix=/usr/local/MySQL(和PHP搭配之最佳组合) 
任何有比上述配置更优的选项的人总是能把他们寄给开发者邮件列表中。

MySQL(和PHP搭配之最佳组合)3.22以前的RPM分发是用户贡献的,自3.22开始,一些RPM是TcX 生成的。 

4.15 安装后期的设置和测试
一旦你已经安装了MySQL(和PHP搭配之最佳组合)(从一个二进制代码或源代码分发),你需要初始化授权表,启动服务器并且保证服务器正确运行。你也可以希望安排服务器在你的系统开机和关机时自动地被启动和停止。 

通常,对从源代码分发的安装,你象这样安装授权表并启动服务器: 

shell> ./scripts/MySQL(和PHP搭配之最佳组合)_install_db
shell> cd MySQL(和PHP搭配之最佳组合)_installation_directory
shell> ./bin/safe_MySQL(和PHP搭配之最佳组合)d &

对二进制分发,这样做: 

shell> cd MySQL(和PHP搭配之最佳组合)_installation_directory
shell> ./bin/MySQL(和PHP搭配之最佳组合)_install_db
shell> ./bin/safe_MySQL(和PHP搭配之最佳组合)d &

测试在MySQL(和PHP搭配之最佳组合)发行的顶级目录是最容易进行的。对二进制分发,这是你的安装目录(典型地类似“/usr/local/MySQL(和PHP搭配之最佳组合)”)。对源代码分发,这是你的MySQL(和PHP搭配之最佳组合)源代码树的主目录。 

在本小节和以后的小节中,下列命令中,BINDIR是到程序如MySQL(和PHP搭配之最佳组合)admin和safe_MySQL(和PHP搭配之最佳组合)d被安装地点的路径。对二进制分发,是在分发内的“bin”目录。对源代码分发,BINDIR可能是“/usr/local/bin”,除非在你运行configure时指定了一个“ /usr/local”以外的安装目录。EXECDIR是MySQL(和PHP搭配之最佳组合)d服务器安装的地点,对二进制分发,这与BINDIR一样。对源代码分发,EXECDIR可能是“/usr/local/libexec”。 

测试详细在下面描述: 

如果必要,启动MySQL(和PHP搭配之最佳组合)d服务器并且建立初始MySQL(和PHP搭配之最佳组合)授权表,包含决定用户如何被允许连接服务器的权限。这通常用MySQL(和PHP搭配之最佳组合)_install_db脚本做: 
shell> scripts/MySQL(和PHP搭配之最佳组合)_install_db

典型地,MySQL(和PHP搭配之最佳组合)_install_db仅在你第一次安装MySQL(和PHP搭配之最佳组合)时需要运行,因此,如果你正在升级现有的安装,你可以跳过这一步。(然而,MySQL(和PHP搭配之最佳组合)_install_db的使用相当安全,并且将不更新已经存在的任何表,因此如果你是不能肯定做什么,你总是可以运行MySQL(和PHP搭配之最佳组合)_install_db。) MySQL(和PHP搭配之最佳组合)_install_db在MySQL(和PHP搭配之最佳组合)数据库里创建6个表(user、db、host、tables_priv、columns_priv和func),初始权限的描述在6.10 设置初始MySQL(和PHP搭配之最佳组合)权限给出。简单地说,这些权限允许MySQL(和PHP搭配之最佳组合) root用户做任何事情,并且允许任何人创建立或使用一个名字以'test'或'test_'开始的数据库。如果你不设置权限表,当你启动服务器时,下列错误将在日志文件出现: 

MySQL(和PHP搭配之最佳组合)d: Can't find file: 'host.frm' 

如果你不是通过明显地执行./bin/safe_MySQL(和PHP搭配之最佳组合)d来启动MySQL(和PHP搭配之最佳组合),上述错误可能也发生在MySQL(和PHP搭配之最佳组合)二进制代码分发!你可能需要作为root运行MySQL(和PHP搭配之最佳组合)_install_db,然而,如果你喜欢, 如果用户能在数据库目录读并且写文件,你可以作为一个非特权(非--root)用户运行MySQL(和PHP搭配之最佳组合)服务器。作为一个非特权用户运行MySQL(和PHP搭配之最佳组合)的指令在18.8 怎样作为一个一般用户运行 MySQL(和PHP搭配之最佳组合)中给出。如果你有MySQL(和PHP搭配之最佳组合)_install_db的问题,见4.15.1 运行MySQL(和PHP搭配之最佳组合)_install_db的问题。因为MySQL(和PHP搭配之最佳组合)_install_db在MySQL(和PHP搭配之最佳组合)发行中,还有一些其他方法运行它: 

你可能想在运行MySQL(和PHP搭配之最佳组合)_install_db前编辑它,改变被安装到授权表中的初始权限。如果你想要在有相同权限的很多机器安装MySQL(和PHP搭配之最佳组合),这很有用。在这种情况下,你可能应该只需要增加几个额外的INSERT语句到MySQL(和PHP搭配之最佳组合).user和MySQL(和PHP搭配之最佳组合).db表中! 
如果你想要在安装授权表后改变什么,你可以运行MySQL(和PHP搭配之最佳组合)_install_db,然后使用MySQL(和PHP搭配之最佳组合) -u root MySQL(和PHP搭配之最佳组合)作为MySQL(和PHP搭配之最佳组合) root用户连接授权表,发出SQL语句直接修改授权表。 
在已经创建了授权表后,有可能全部再次创建。如果你已经安装了表但是随后又想要在编辑MySQL(和PHP搭配之最佳组合)_install_db以后再创建,你可能想要这样做。 
关于这些选项的更多信息,见6.10 建立初始MySQL(和PHP搭配之最佳组合)权限。 

象这样启动MySQL(和PHP搭配之最佳组合)服务器: 
shell> cd MySQL(和PHP搭配之最佳组合)_installation_directory
shell> bin/safe_MySQL(和PHP搭配之最佳组合)d &

如果你启动服务器的问题,见4.15.2 启动MySQL(和PHP搭配之最佳组合)服务器的问题. 

使用MySQL(和PHP搭配之最佳组合)admin证实服务器正在运行。下列命令提供简单的测试来检查服务器启动和连接的应答: 
shell> BINDIR/MySQL(和PHP搭配之最佳组合)admin version 
shell> BINDIR/MySQL(和PHP搭配之最佳组合)admin variables

从MySQL(和PHP搭配之最佳组合)admin version的输出根据你的平台和MySQL(和PHP搭配之最佳组合)版本略有不同,但是应该类似如下显示: 
shell> BINDIR/MySQL(和PHP搭配之最佳组合)admin version
MySQL(和PHP搭配之最佳组合)admin Ver 6.3 Distrib 3.22.9-beta, for pc-linux-gnu on i686
TCX Datakonsult AB, by Monty

Server version     3.22.9-beta
Protocol version    10
Connection       Localhost via UNIX socket
TCP port        3306
UNIX socket       /tmp/MySQL(和PHP搭配之最佳组合).sock
Uptime:         16 sec

Running threads: 1 Questions: 20 Reloads: 2 Open tables: 3

为了感觉你能用BINDIR/MySQL(和PHP搭配之最佳组合)admin做其他事情,用--help选项调用它。 

证实你能关掉服务器: 
shell> BINDIR/MySQL(和PHP搭配之最佳组合)admin -u root shutdown

证实你能重启服务器。使用safe_MySQL(和PHP搭配之最佳组合)d或直接调用MySQL(和PHP搭配之最佳组合)d进行,例如: 
shell> BINDIR/safe_MySQL(和PHP搭配之最佳组合)d --log &

如果safe_MySQL(和PHP搭配之最佳组合)d失败,从MySQL(和PHP搭配之最佳组合)安装目录尝试运行它(如果你已经不在那里)。如果还不工作,见4.15.2 启动MySQL(和PHP搭配之最佳组合)服务器的问题。 

运行一些简单的测试证实服务器正在工作。输出应该类似于下面所显示的: 
shell> BINDIR/MySQL(和PHP搭配之最佳组合)show
+-----------+
| Databases |
+-----------+
| MySQL(和PHP搭配之最佳组合)   |
+-----------+

shell> BINDIR/MySQL(和PHP搭配之最佳组合)show MySQL(和PHP搭配之最佳组合)
Database: MySQL(和PHP搭配之最佳组合)
+--------------+
|  Tables  |
+--------------+
| columns_priv |
| db      |
| func     |
| host     |
| tables_priv |
| user     |
+--------------+

shell> BINDIR/MySQL(和PHP搭配之最佳组合) -e "select host,db,user from db" MySQL(和PHP搭配之最佳组合)
+------+--------+------+
| host | db   | user |
+------+--------+------+
| %  | test  |   |
| %  | test_% |   |
+------+--------+------+

在“sql-bench”目录(在MySQL(和PHP搭配之最佳组合)安装目录下)下还有基准测试套件,你能用来比较在不同的平台上MySQL(和PHP搭配之最佳组合)表现如何。“ sql-bench/Results”目录包含对不同的数据库和平台许多运行结果。为了运行所有的测试,执行这些命令: 


shell> cd sql-bench
shell> run-all-tests

如果你没有“sql-bench”目录,你可能在对二进制分发使用一个RPM(源代码分发的RPM包括基准目录)。在这种情况下,在你能使用它以前,你必须首先安装基准套件。从MySQL(和PHP搭配之最佳组合) 3.22开始,有名为“MySQL(和PHP搭配之最佳组合)-bench-VERSION-i386.rpm”的基准RPM包,它们包含基准代码和数据。如果你有源代码分发,你也可以在“tests”子目录下运行测试。例如,运行“auto_increment.tst”,这样做: 

shell> BINDIR/MySQL(和PHP搭配之最佳组合) -vvf test < ./tests/auto_increment.tst

期望的结果被显示在“ ./tests/auto_increment.res”文件中。 

4.15.1 运行MySQL(和PHP搭配之最佳组合)_install_db的问题
这节列出在你运行MySQL(和PHP搭配之最佳组合)_install_db时,你可能遇见的问题: 

MySQL(和PHP搭配之最佳组合)_install_db不安装授权表 
在显示下列消息以后,你可以发现MySQL(和PHP搭配之最佳组合)_install_db不能安装授权表并终止: 
starting MySQL(和PHP搭配之最佳组合)d daemon with databases from XXXXXX
MySQL(和PHP搭配之最佳组合) daemon ended

在这种情况下,你应该很小心地检验日志文件!日志文件应该位于目录“XXXXXX”,用错误消息命名,并且应该指出为什么MySQL(和PHP搭配之最佳组合)d没启动。如果你不理解发生的事情,当你使用MySQL(和PHP搭配之最佳组合)bug邮寄一份错误报告时,包含日志文件!见2.3 怎样报告错误或问题。 

已经有一个MySQL(和PHP搭配之最佳组合)d守护程序在运行 
在这种情况下,你可能根本不必运行MySQL(和PHP搭配之最佳组合)_install_db。当你第一次安装MySQL(和PHP搭配之最佳组合)时,你必须只运行MySQL(和PHP搭配之最佳组合)_install_db一次。 
当一个守护进程正在运行时,安装第二个MySQL(和PHP搭配之最佳组合)d守护进程不工作 
这只有在当你已经有已存在的MySQL(和PHP搭配之最佳组合)安装但是想要把新安装放在一个不同的地方时才会发生(例如,为了测试或者也许你简单地想要同时运行2个安装)。通常当你试着运行第二个服务器时,发生的问题是它试图和旧一个使用同样的套接字和端口。在这种情况下,你将得到错误消息:Can't start server: Bind on TCP/IP port: Address already in use或Can't start server : Bind on unix socket...你能用一个不同的套接字和端口启动新的服务器,如下: 
shell> MySQL(和PHP搭配之最佳组合)_UNIX_PORT=/tmp/MySQL(和PHP搭配之最佳组合)d-new.sock
shell> MySQL(和PHP搭配之最佳组合)_TCP_PORT=3307
shell> export MySQL(和PHP搭配之最佳组合)_UNIX_PORT MySQL(和PHP搭配之最佳组合)_TCP_PORT
shell> scripts/MySQL(和PHP搭配之最佳组合)_install_db
shell> bin/safe_MySQL(和PHP搭配之最佳组合)d &

在这以后,你应该编辑你的服务器引导脚本手迹用不同的套接字和端口启动两个守护进程。例如,它能调用safe_MySQL(和PHP搭配之最佳组合)d两次,但是对每次调用使用不同的--socket、--port和--basedir选项。 

你没有“ /tmp ”的写权限 
如果你没有写权限在缺省地方(在“/tmp”里)创建一个套接字文件,或没有在“/tmp”创建临时文件的许可,在运行MySQL(和PHP搭配之最佳组合)_install_db或当启动或使用MySQL(和PHP搭配之最佳组合)d时,你将得到一个错误。你可以如下地指定一个不同的套接字和临时目录: 
shell> TMPDIR=/some_tmp_dir/ 
shell> MySQL(和PHP搭配之最佳组合)_UNIX_PORT=/some_tmp_dir/MySQL(和PHP搭配之最佳组合)d.sock 
shell> export TMPDIR MySQL(和PHP搭配之最佳组合)_UNIX_PORT

“some_tmp_dir”应该是你有写许可的某个目录的路径。在这以后,你应该能运行MySQL(和PHP搭配之最佳组合)_install_db并且这些命令启动服务器: 

shell> scripts/MySQL(和PHP搭配之最佳组合)_install_db
shell> BINDIR/safe_MySQL(和PHP搭配之最佳组合)d &

MySQL(和PHP搭配之最佳组合)d立刻崩溃 
如果你正在运行RedHat 5.0,有一个比2.0.7-5旧的glibc版本,你应该保证你安装了glibc所有补丁!在MySQL(和PHP搭配之最佳组合)邮件档案中有很多关于它的信息。邮件档案的链接可在联机MySQL(和PHP搭配之最佳组合)文档页得到。也可见4.11.5 Linux 注意事项(所有Linux版本)。你也可以手工启动MySQL(和PHP搭配之最佳组合)d,使用--skip-grant选项并且增加使用MySQL(和PHP搭配之最佳组合)本身的权限信息: 
shell> BINDIR/safe_MySQL(和PHP搭配之最佳组合)d --skip-grant &
shell> BINDIR/MySQL(和PHP搭配之最佳组合) -u root MySQL(和PHP搭配之最佳组合)

从MySQL(和PHP搭配之最佳组合),手工执行在MySQL(和PHP搭配之最佳组合)_install_db里面的SQL命令。保证你随后运行MySQL(和PHP搭配之最佳组合)admin reload告诉服务器再装入授权表。 

4.15.2 启动MySQL(和PHP搭配之最佳组合)服务器的问题
通常,你用3个方法之一启动MySQL(和PHP搭配之最佳组合)d服务器: 

通过调用MySQL(和PHP搭配之最佳组合).server。这个脚本主要用于系统启动和关闭,更全面的描述在4.15.3 自动启动和停止MySQL(和PHP搭配之最佳组合)。 
通过调用safe_MySQL(和PHP搭配之最佳组合)d,它试图为MySQL(和PHP搭配之最佳组合)d决定正确的选项并然后用那些选择运行它。 
通过直接调用MySQL(和PHP搭配之最佳组合)d。 
无论你使用哪个方法启动服务器,如果它没有正确启动,检查日志文件看你是否能发现为什么。日志文件位于数据目录(对二进制分发一般是“/usr/local/MySQL(和PHP搭配之最佳组合)/data”,对源代码分发是“/usr/local/var”)。用“host_name.err”和“host_name.log”形式的名字在数据目录下查找文件,这里host_name是你服务器主机的名字,然后检查这些文件的最后几行: 

shell> tail host_name.err
shell> tail host_name.log

当MySQL(和PHP搭配之最佳组合)d守护进程启动时,它把目录改变到数据目录。这是它期望写日志文件和pid(进程ID)文件的地方,和它期望在那儿找到数据库。 

数据目录地点是在分发编译时定死的。然而,如果MySQL(和PHP搭配之最佳组合)d期望它在你的系统上其他某个地方找到数据目录,它将工作不正常。如果你有不正确路径的问题,你可使用--help选项调用MySQL(和PHP搭配之最佳组合)d,找到MySQL(和PHP搭配之最佳组合)d允许什么选项和缺省路径设置是什么。你能通过指定正确的路径作为MySQL(和PHP搭配之最佳组合)d命令行参数来覆盖缺省值。(这些选择也能用于safe_MySQL(和PHP搭配之最佳组合)d。)

通常你应该只需要告诉MySQL(和PHP搭配之最佳组合)d基本目录,在它下面安装MySQL(和PHP搭配之最佳组合)。你可以用--basedir选项做到,你也能使用--help检查改变路径选项的效果(注意,--help必须是MySQL(和PHP搭配之最佳组合)d命令的最后选项)。例如: 

shell> EXECDIR/MySQL(和PHP搭配之最佳组合)d --basedir=/usr/local --help

一旦你确定你想要的路径设置,不用--help选项启动服务器。 

如果你得到下列错误,它意味着MySQL(和PHP搭配之最佳组合)d正在试图使用某些其他程序(或其他MySQL(和PHP搭配之最佳组合)d服务器)已经正在使用TCP/IP端口或套接字: 

Can't start server: Bind on TCP/IP port: Address already in use
 或
Can't start server : Bind on unix socket...

使用ps保证你没有另外一个MySQL(和PHP搭配之最佳组合)d服务器正在运行。如果你不能发现其他运行的服务器,你可以尝试执行命令telnet your-host-name tcp-ip-port-number并且按几次RETURN键,如果你没有得到一个错误消息,像telnet: Unable to connect to remote host: Connection refused,某个东西正在使用MySQL(和PHP搭配之最佳组合)d正在试图使用的TCP/IP端口,见4.15.1 运行MySQL(和PHP搭配之最佳组合)_install_db的问题和19.3 在同一台机器上运行多个MySQL(和PHP搭配之最佳组合)服务器。 

safe_MySQL(和PHP搭配之最佳组合)d脚本被编写以便能正常地启动一个从MySQL(和PHP搭配之最佳组合)源代码或二进制代码版本安装的服务器,就算这些在稍微不同的地点安装服务器。safe_MySQL(和PHP搭配之最佳组合)d希望这些条件之一是真的: 

服务器和数据库能在相对safe_MySQL(和PHP搭配之最佳组合)d被调用的目录下找到。safe_MySQL(和PHP搭配之最佳组合)d在它的工作目录下面找“bin”和“data”目录(对二进制分发)或“libexec”和“var”目录(对源代码分发)。如果你从你的MySQL(和PHP搭配之最佳组合)安装目录(例如,对二进制分发为“/usr/local/MySQL(和PHP搭配之最佳组合)”)执行safe_MySQL(和PHP搭配之最佳组合)d,这个条件应该满足。 
如果服务器和数据库不能在相对其工作目录找到,safe_MySQL(和PHP搭配之最佳组合)d试图通过绝对路径找到他们。典型的地点是“ /usr/local/libexec”和“/usr/local/var”。实际的地点在构造来自分发的safe_MySQL(和PHP搭配之最佳组合)d时确定,如果MySQL(和PHP搭配之最佳组合)安装在一个标准的地点,他们应该是正确的。 
因为safe_MySQL(和PHP搭配之最佳组合)d将试图在相对它自己的工作目录下找到服务器和数据库,你可以在任何地方安装MySQL(和PHP搭配之最佳组合)的二进制分发,只要你从MySQL(和PHP搭配之最佳组合)安装目录启动safe_MySQL(和PHP搭配之最佳组合)d即可: 

shell> cd MySQL(和PHP搭配之最佳组合)_installation_directory
shell> bin/safe_MySQL(和PHP搭配之最佳组合)d &

如果safe_MySQL(和PHP搭配之最佳组合)d失败,甚至在从MySQL(和PHP搭配之最佳组合)安装目录调用时,你可以修改它以便使用到MySQL(和PHP搭配之最佳组合)d路径并且对你的系统的路径选项是正确的。注意,如果在将来你升级MySQL(和PHP搭配之最佳组合),你的safe_MySQL(和PHP搭配之最佳组合)d修改版本将被覆盖,因此你应该做一个你能重新安装的编辑过的版本的拷贝。 

如果MySQL(和PHP搭配之最佳组合)d当前正在运行,通过执行这个命令,你能发现它正在使用什么路径设置: 

shell> MySQL(和PHP搭配之最佳组合)admin variables



shell> MySQL(和PHP搭配之最佳组合)admin -h 'your-host-name' variables

如果safe_MySQL(和PHP搭配之最佳组合)d启动服务器但是你不能与它连接,你应该保证你在“/etc/hosts”里面有一个条目,看起来像这样: 

127.0.0.1 localhost
这个问题仅发生在没有一个能工作的线程库的系统上并且对该系统MySQL(和PHP搭配之最佳组合)必须配置为使用MIT-pthreads。 

4.15.3 自动启动和停止MySQL(和PHP搭配之最佳组合)
MySQL(和PHP搭配之最佳组合).server脚本可以被用来启动或停止服务器,通过用start或stop参数调用它: 

shell> MySQL(和PHP搭配之最佳组合).server start
shell> MySQL(和PHP搭配之最佳组合).server stop

MySQL(和PHP搭配之最佳组合).server可在MySQL(和PHP搭配之最佳组合)安装目录下的“share/MySQL(和PHP搭配之最佳组合)”目录里找到,或在MySQL(和PHP搭配之最佳组合)源代码树的“support-files”目录下找到。 

在MySQL(和PHP搭配之最佳组合).server启动服务器之前,它把目录改变到MySQL(和PHP搭配之最佳组合)安装目录,然后调用safe_MySQL(和PHP搭配之最佳组合)d。如果你有在一个非标准的地点安装的二进制分发,你可能需要编辑MySQL(和PHP搭配之最佳组合).server。修改它,运行safe_MySQL(和PHP搭配之最佳组合)d前,cd到正确的目录。如果你想要作为一些特定的用户运行服务器,你可以改变MySQL(和PHP搭配之最佳组合)_daemon_user=root行使用其他用户,你也能修改MySQL(和PHP搭配之最佳组合).server把其他选项传给safe_MySQL(和PHP搭配之最佳组合)d。 

MySQL(和PHP搭配之最佳组合).server stop通过向服务器发出一个信号停止它。你可手工执行MySQL(和PHP搭配之最佳组合)admin shutdown关闭服务器。 

当你开始使用MySQL(和PHP搭配之最佳组合)作为生产应用时,你可能想要增加这些启动并且停止命令到在你的“/etc/rc * 文件中适当的地方。注意如果你修改MySQL(和PHP搭配之最佳组合).server,那么如果某个时候你升级MySQL(和PHP搭配之最佳组合)时,你的修改版本将被覆盖,因此你应该做一个你可重新安装的编辑过的版本的拷贝。 

如果你的系统使用“/etc/rc.local”启动外部脚本,你应该添加下列到其中: 

/bin/sh -c 'cd /usr/local/MySQL(和PHP搭配之最佳组合) ; ./bin/safe_MySQL(和PHP搭配之最佳组合)d &' 
你也可以在一个全局“/etc/my.cnf”文件中增加MySQL(和PHP搭配之最佳组合).server的选项。一个典型的“/etc/my.cnf”文件可能看起来像这样: 

MySQL(和PHP搭配之最佳组合)d]
datadir=/usr/local/MySQL(和PHP搭配之最佳组合)/var
socket=/tmp/MySQL(和PHP搭配之最佳组合)d.sock
port=3306

[MySQL(和PHP搭配之最佳组合).server]
user=MySQL(和PHP搭配之最佳组合)
basedir=/usr/local/MySQL(和PHP搭配之最佳组合)

MySQL(和PHP搭配之最佳组合).server脚本使用下列变量:user、datadir、basedir、bindir和pid-file。 
见4.15.4 选项文件。 

4.15.4 选项文件
MySQL(和PHP搭配之最佳组合)3.22 可以从选项文件中为服务器和客户读取缺省启动选项。 

在Unix上,MySQL(和PHP搭配之最佳组合)从下列文件读取缺省选择: 


文件名 用途 
/etc/my.cnf 全局选项 
DATADIR/my.cnf 服务器特定的选项目 
~/.my.cnf 用户特定的选项 

DATADIR是MySQL(和PHP搭配之最佳组合)的数据目录(典型地对二进制安装是“/usr/local/MySQL(和PHP搭配之最佳组合)/data”或对源代码安装是“/usr/local/var”)。注意:这是在配置时间指定的目录,不是MySQL(和PHP搭配之最佳组合)d启动时用--datadir指定的目录!(--datadir在服务器寻找选项文件的地方无效,因为它以前寻找他们,它处理任何命令行参数。)

MySQL(和PHP搭配之最佳组合)在Win32上从下列文件读取缺省选项: 

文件名 用途 
windows-system-directorymy.ini 
C:my.cnf 全局选项 
C:MySQL(和PHP搭配之最佳组合)datamy.cnf 服务器特定的选项 

注意,在Win32上你应该用/而不是指定所有的路径,如果你使用,你需要指定两个,因为在MySQL(和PHP搭配之最佳组合)里面是转义字符。 

MySQL(和PHP搭配之最佳组合)试图以上述所列的顺序读取选项文件。如果存在多个选项文件,在一个后面文件读取的选项优先于在先前读取的一个文件中指定的同一个选项,在命令行上指定的选项优先于在任何选项文件指定了的选项。有些选择能使用环境变量指定,在命令行或在选项文件指定的选项优先于环境变量。 

下列程序支持选项文件:MySQL(和PHP搭配之最佳组合)、MySQL(和PHP搭配之最佳组合)admin、MySQL(和PHP搭配之最佳组合)d、MySQL(和PHP搭配之最佳组合)dump、MySQL(和PHP搭配之最佳组合)import、MySQL(和PHP搭配之最佳组合).server、myisamchk和myisampack。 

你能使用选项文件指定一个程序支持的任意长的选项!用--help选项运行程序可得到的可用选项的表。 

一个选项文件可以包含下列形式的行: 

#comment 
注释行以“#”或“;”开始,空行被忽略。 
[group] 
group是你想为其设置选项的程序或组的名字。在一个组行后,任何option或set-variable行应用于命名的组,直到选择文件结束或其他组的给出。 
option 
这等价于在命令行上的--option。 
option=value 
这等价于在命令行上的--option=value。 
set-variable = variable=value 
这等价于在命令行上的--set-variable variable=value。该语法必须被用来设置一个MySQL(和PHP搭配之最佳组合)d变量。 
client组允许你指定适用于所有MySQL(和PHP搭配之最佳组合)客户的选项(不是MySQL(和PHP搭配之最佳组合)d)。这是理想的组来指定你用来与服务器连接的口令。(但是保证只是选项文件本身是可读的和可写的。)

注意,对域选项和值,所有头部和尾部空白自动被删除。你可以在的值串中使用转义顺序“”、“ ”、“
”、“
”、“”和“s”(“s”==空白)。 

这是一个典型的全局选项文件: 

[client] 
port=3306 
socket=/tmp/MySQL(和PHP搭配之最佳组合).sock 
[MySQL(和PHP搭配之最佳组合)d] 
port=3306 
socket=/tmp/MySQL(和PHP搭配之最佳组合).sock 
set-variable = key_buffer=16M 
set-variable = max_allowed_packet=1M 

[MySQL(和PHP搭配之最佳组合)dump] 
quick 

这是典型的用户选项文件: 

[client]
# The following password will be sent to all standard MySQL(和PHP搭配之最佳组合) clients
password=my_password

[MySQL(和PHP搭配之最佳组合)]
no-auto-rehash

如果你有一个源代码分发,你将在“support-files”目录下找到一个名为“my-example.cnf”样品配置文件。如果你有二进制分发,在“DIR/share/MySQL(和PHP搭配之最佳组合)”目录下查找,在此DIR是MySQL(和PHP搭配之最佳组合)安装目录的路径(一般是“/usr/local/MySQL(和PHP搭配之最佳组合)”)。你可以拷贝“my-example.cnf”到你的主目录(重新命名拷贝为“.my.cnf”)来试验。 

为了告诉一个MySQL(和PHP搭配之最佳组合)程序不读任何选项文件,在命令行上指定--no-defaults作为第一个选项。这必须是第一个选项,否则它将无效!如果你想检查使用哪个选项,你可以给出--print-defaults选项作为第一个选项。 

如果你想要强制使用一个特定配置文件,你可以使用选项--defaults-file=full-path-to-default-file。如果你这样做,只有指定的文件将被读取。 

开发者注意:选项文件的处理简单地通过处理所有在任何命令行前参数的匹配选项来实现(即,在适当的组里的选项),这对使用多次指定的一个选项的最后实例的程序工作的很好。如果你有这样一个处理多重指定选项但不读选项文件的旧程序, 你只需要增加2行给与它那种能力。检查任何标准的MySQL(和PHP搭配之最佳组合)客户的源代码看怎样做。 

4.16 升级/降级MySQL(和PHP搭配之最佳组合)时有什么特别的事情要做?
只要你有MySQL(和PHP搭配之最佳组合)同一个的基础版本,你总可以在同样的体系结构上的不同版本之间的移动MySQL(和PHP搭配之最佳组合)表格(form)和数据文件。当前的基础版本是3。如果你通过重新编译MySQL(和PHP搭配之最佳组合)改变字符集(也可以改变排序顺序),你必须在所有的表上运行myisamchk -r -q,否则你的索引不能正确被排序。 

如果你偏执于或担心新版本,你总能重新命名的旧MySQL(和PHP搭配之最佳组合)d为类似于MySQL(和PHP搭配之最佳组合)d-'old-version-number'。那么如果你的新MySQL(和PHP搭配之最佳组合)d做一些意外的事情,你可以简单地关掉它并重启你的旧MySQL(和PHP搭配之最佳组合)d! 

当你做一个升级时,当然你也应该备份你的旧数据库。有时有点偏执狂是好的! 

在升级后,如果你重新编译客户程遇到问题,像Commands out of sync或意外的核心倾倒,在编译你的程序时,你可能使用了一个旧的头文件或库文件。在这种情况下,你应该检查你的“MySQL(和PHP搭配之最佳组合).h”文件和“libMySQL(和PHP搭配之最佳组合)client.a”库文件的日期以证实他们来自新的MySQL(和PHP搭配之最佳组合)发行。如果不是,请重新编译你的程序! 

如果你有些问题,新的MySQL(和PHP搭配之最佳组合)d服务器不想启动或你不能没有口令连接,检查你确实没有来自你的旧安装的一些旧的“my.cnf”文件!你可以用program-name --print-defaults检查。如果这输出任何非程序名字的任何东西,你有一个活跃my.cnf文件将可以影响一些事情! 

无论何时你安装一个新版本的MySQL(和PHP搭配之最佳组合),重新构造并重新安装Msql-MySQL(和PHP搭配之最佳组合)-modules分发是一个好主意,特别是在升级MySQL(和PHP搭配之最佳组合)后,如果你注意到诸如你的所有DBI脚本倾倒核心症状。 


4.16.1 从一个3.22版本升级到3.23
MySQL(和PHP搭配之最佳组合) 3.23支持新MyISAM类型和旧ISAM类型的表。你不必须变换你的旧式表给3.23使用。缺省地,所有的新表将用类型MyISAM创建(除非你使用--default-table-type=isam选项启动MySQL(和PHP搭配之最佳组合)d)。你可以用ALTER TABLE或Perl脚本MySQL(和PHP搭配之最佳组合)_convert_table_format将一个ISAM表转换成一个MyISA表。 

3.22和3.21客户将毫无问题地与一个3.23服务器一起工作。 

当升级到3.23时,下面列出你必须注意的事情: 

INNER和DELAYED现在是保留字。 
FLOAT(X)现在是一个真正的浮点类型。 
当声明DECIMAL(length,dec)时,长度参数不再包括一个符号或小数点位置。 
一个TIME字符串必须是下列现有格式之一:[[[DAYS] [H]H:]MM:]SS[.fraction]或[[[[[H]H]H]H]MM]SS[.fraction]。 
现在,LIKE使用'='同样的字符比较规则比较字符串。如果你要求旧的行为,你可以用CXXFLAGS=-DLIKE_CMP_TOUPPER标志编以MySQL(和PHP搭配之最佳组合)。 
REGEXP现在对正常(不是二进制的)字符串是忽略大小写的。 
在你检查/修复表时,对MyISAM表(.MYI),你应该使用myisamchk,而对ISAM(.ISM)表使用isamchk。 
如果你想要你的MySQL(和PHP搭配之最佳组合)dumps在MySQL(和PHP搭配之最佳组合)3.22和3.23之间兼容,你应该不使用MySQL(和PHP搭配之最佳组合)dump的--opt或--full选项。 
检查所有对DATE_FORMAT()的调用,保证在在每个格式字符前有一个“%”。 
MySQL(和PHP搭配之最佳组合)_fetch_fields_direct现在是函数(它以前是一个宏)并且它返回一个指向MySQL(和PHP搭配之最佳组合)_FIELD的指针而不是一个MySQL(和PHP搭配之最佳组合)_FIELD。 
MySQL(和PHP搭配之最佳组合)_num_fields()可以不再被用在一个MySQL(和PHP搭配之最佳组合)*对象上(它现在是一个函数,拿MySQL(和PHP搭配之最佳组合)_RES*作为一个参数)。相反你现在应该使用MySQL(和PHP搭配之最佳组合)_field_count()。 
在MySQL(和PHP搭配之最佳组合)3.22,SELECT DISTINCT ...的输出几乎总是被排序的。在3.23上,你必须使用GROUP BY或ORDER BY获得排序的输出。 
如果没有匹配的行,SUM()现在返回NULL,而不是 0。这是遵照ANSI SQL。 
新的限制词:CASE、THEN、WHEN、ELSE和END。 

4.16.2 从一个3.21版本升级到3.22
没有影响相容性的东西在3.21和3.22之间已改变。唯一的缺陷是用DATE类类型创建的新表将使用新方法存储日期。你不能从一个MySQL(和PHP搭配之最佳组合)d旧版本存取这些新字段。 

在安装MySQL(和PHP搭配之最佳组合)3.22 以后,你应该启动新的服务器并且然后运行MySQL(和PHP搭配之最佳组合)_fix_privilege_tables脚本。这将增加你使用GRANT命令所需的新权限。如果你忘记了这个,当你试着使用ALTER TABLE, CREATE INDEX或DROP INDEX时,你将得到Access denied。如果你的MySQL(和PHP搭配之最佳组合)根用户要求一个口令,你应该把它作为一个参数给MySQL(和PHP搭配之最佳组合)_fix_privilege_tables。 

MySQL(和PHP搭配之最佳组合)_real_connect()的C API接口改变了。如果你有一个旧的客户程序调用该函数,你必须放一个0作为新db参数(或为了快速连接重新编码发送的db单元的客户)。你在MySQL(和PHP搭配之最佳组合)_real_connect()前也必须调用MySQL(和PHP搭配之最佳组合)_init()!做这个改变允许新的MySQL(和PHP搭配之最佳组合)_options()函数在MySQL(和PHP搭配之最佳组合)处理程序结构中保存选项。 

4.16.3 从一个3.20版本升级到3.21
如果你正在运行一个比3.20.28旧的版本并且想要换到3.21.x,你需要做下列事情: 

你能用safe_MySQL(和PHP搭配之最佳组合)d --old-protocol启动MySQL(和PHP搭配之最佳组合)d3.21服务器从3.20分发的客户使用它。在这种情况下,新客户函数MySQL(和PHP搭配之最佳组合)_errno()将不返回任何服务器错误,而仅仅是CR_UNKNOWN_ERROR(但是它为客户错误服务)并且服务器使用旧的passwd() 检查而非新的一个。 

如果你在而不是对MySQL(和PHP搭配之最佳组合)d使用--old-protocol选项,你将需要做下列改变: 

所有的客户代码必须重新编译。如果你正在使用ODBC,你必须得到新的MyODBC 2.x驱动程序。 
脚本scripts/add_long_password必须运行以便变换在MySQL(和PHP搭配之最佳组合).user表中的Password字段为CHAR(16)。 
所有在MySQL(和PHP搭配之最佳组合).user中的口令必须被重新赋值(为了得到62位而非31位口令)。 
表格式没变化,因此你不必须变换任何表。 
MySQL(和PHP搭配之最佳组合)3.20.28和以上版本可以处理新的user表格式而不影响客户。如果你有一个比3.20.28早的MySQL(和PHP搭配之最佳组合)版本,如果你变换user表,口令将不再与之工作。因此为了安全,你首先应该升级到至少3.20.28并且然后升级到3.21.x。

新的客户代码可与一个3.20.x 版的MySQL(和PHP搭配之最佳组合)d服务器一起工作,因此如果你遇到3.21.x的问题,你可以使用旧的3.20.x服务器而无须重新编译客户。 

如果你对MySQL(和PHP搭配之最佳组合)d不使用--old-protocol选项,旧的客户将发出错误消息: 

ERROR: Protocol mismatch. Server Version = 10 Client Version = 9

新的Perl DBI/DBD接口也支持旧的MySQL(和PHP搭配之最佳组合)perl接口。如果你使用MySQL(和PHP搭配之最佳组合)perl,你必须做的唯一改变是改变到connect()函数的参数。新参数是:host、database、user、password(user和password参数改变了位置)。见20.5.2 DBI接口。 

下列变化可能影响到旧的应用程序的查询: 

现在HAVING必须在任何ORDER BY子句前被指定。 
LOCATE()参数被交换了。 
有一些新的保留字。最著名是DATE、TIME和TIMESTAMP。 

4.16.4 升级到其他体系结构
如果你正在使用MySQL(和PHP搭配之最佳组合)3.23,你能在不同的支持同样浮点格式的体系结构之间拷贝.frm、.MYI和.MYD。(MySQL(和PHP搭配之最佳组合)考虑了任何字节交换的问题)。 

MySQL(和PHP搭配之最佳组合) ISAM数据“ *.ISD”和索引文件“ *.ISM”文件是依赖于系统结构并在某些情况下依赖于OS。如果你想要移动你的应用程序到有与你当前系统不同的体系结构或OS的其他机器上,你不应该试图通过简单地拷贝文件到另外的机器上来移动一个数据库,相反使用MySQL(和PHP搭配之最佳组合)dump。 

缺省地,MySQL(和PHP搭配之最佳组合)dump将创建一个满是SQL语句的文件,然后你可以把文件转移到其他机器上并且把它作为MySQL(和PHP搭配之最佳组合)客户的输入。 

试一试MySQL(和PHP搭配之最佳组合)dump --help看可得到什么选项。如果你正在移动数据到一个更新的MySQL(和PHP搭配之最佳组合)版本,你应该用得到的更新的版本使用MySQL(和PHP搭配之最佳组合)dump --opt得到一个快速、紧凑的倒出(dump)。 

最容易(尽管不是最快)的在2台机器之间移动一个数据库的方法是在数据库所在的机器上运行下列命令: 

shell> MySQL(和PHP搭配之最佳组合)admin -h 'other hostname' create db_name
shell> MySQL(和PHP搭配之最佳组合)dump --opt db_name 
    | MySQL(和PHP搭配之最佳组合) -h 'other hostname' db_name

如果你想要在一个慢的网络上从一台远程机器上拷贝一个数据库,你可以使用: 

shell> MySQL(和PHP搭配之最佳组合)admin create db_name 
shell> MySQL(和PHP搭配之最佳组合)dump -h 'other hostname' --opt --compress db_name 
| MySQL(和PHP搭配之最佳组合) db_name

你也可以在一个文件中存储结果, 然后把文件转移到目标机器并且在那里装载文件到数据库。例如,你能象这样在源机器上倾倒一个数据库到一个文件: 

shell> MySQL(和PHP搭配之最佳组合)dump --quick db_name | gzip > db_name.contents.gz 

(本例创建的文件被压缩) 转移包含数据库内容的文件到目标机器,并且在那里运行这些命令: 

shell> MySQL(和PHP搭配之最佳组合)admin create db_name
shell> gunzip < db_name.contents.gz | MySQL(和PHP搭配之最佳组合) db_name

你也可以使用MySQL(和PHP搭配之最佳组合)dump和MySQL(和PHP搭配之最佳组合)import完成数据库转移。对大数据库表,这比简单地使用MySQL(和PHP搭配之最佳组合)dump更快。在下列命令中,DUMPDIR代表你用来存储来自MySQL(和PHP搭配之最佳组合)dump的输出的目录的完整的路径。 

首先,为输出文件和倾倒数据库创建目录: 

shell> mkdir DUMPDIR
shell> MySQL(和PHP搭配之最佳组合)dump --tab=DUMPDIR db_name

然后转移在DUMPDIR目录下的文件到目标机器的一些相应目录并且在那里装载文件到MySQL(和PHP搭配之最佳组合): 

shell> MySQL(和PHP搭配之最佳组合)admin create db_name      # create database
shell> cat DUMPDIR/*.sql | MySQL(和PHP搭配之最佳组合) db_name  # create tables in database
shell> MySQL(和PHP搭配之最佳组合)import db_name DUMPDIR/*.txt  # load data into tables

另外,别忘记拷贝MySQL(和PHP搭配之最佳组合)数据库,因为那是授权表(user、db、host)被存储的地方。你可能必须作为MySQL(和PHP搭配之最佳组合) root用户在新机器上运行命令,直到你让MySQL(和PHP搭配之最佳组合)数据库到位。 

当你在新机器上导入MySQL(和PHP搭配之最佳组合)数据库后,执行MySQL(和PHP搭配之最佳组合)admin flush-privileges以便服务器再次装入授权表信息。 

Tags:MySQL 参考

编辑录入:coldstar [复制链接] [打 印]
赞助商链接