当前位置: 首页 > 后端技术 > Java

估计是音量上瘾了,反正睡不着!让一个虫子居然把我搞得两败俱伤!

时间:2023-04-02 01:33:13 Java

浣滆€咃細灏忓倕鍗氬锛歨ttps://bugstack.cn娌夋穩锛屽垎浜紝鎴愰暱锛岃鑷繁鍜屼粬浜烘湁鎵€鏀惰幏锛侌煒?.鍓嶈█锛氫竴涓猙ug娌℃兂鍒颁竴涓猙ug绔熺劧鏉ユ児鎴戜袱娆★紒鎴戝彲鑳芥矇杩蜂簬婊氬姩銆傚弽姝f垜鏄潯涓嶇潃銆傛垜鍧愯捣鏉ユ墦寮€Mac鍜屽鎺ユ樉绀哄櫒銆傝繖涓敊璇病鏈変换浣曞師鍥犮€傛垜榛橀粯鍦扮湅鐫€鎵撳嵃寮傚父鐨勫睆骞曘€備竴涓槸鎴戠殑锛屽彟涓€涓篃鏄垜鐨勩€傚彲鑳芥渶杩戞槸閲忔簮锛岄噺涓婄樉浜嗐€傚厛鏄€婃墜鍐橲pring銆嬶紝鐒跺悗鏄€婃墜鍐橫ybatis銆嬶紝娌℃兂鍒颁竴涓皬闂绔熺劧鎶婃垜鎼炵牳浜嗕袱娆★紒浠婂ぉ杩欎釜闂涓昏浣撶幇鍦ㄥぇ瀹跺钩鏃朵娇鐢ㄧ殑Mybatis涓娿€傛彃鍏ユ暟鎹椂锛屾垜浠彲浠ラ€氳繃鍏ュ弬瀵硅薄杩斿洖搴撹〃绱㈠紩鐨勮繑鍥炲€笺€備絾鏄€氳繃鎴戣嚜宸辨墜鍐欑殑Mybatis锛屾瘡娆¢兘杩斿洖0锛岃€屼笉鏄渶鍚庝竴娆℃彃鍏ュ簱琛ㄧ殑绱㈠紩鍊笺€傚洜涓烘槸鎵嬪啓鐨勶紝骞舵病鏈夌洿鎺ヤ娇鐢∕ybatis锛屾墍浠ユ垜浼氫粠鏂囦欢瑙f瀽銆佸璞℃槧灏勩€丼QL鏌ヨ銆佺粨鏋滄墦鍖呯瓑鏂归潰缁х画鎺掓煡锛屼絾鏄棶棰樹笉灏卞湪杩欓噷鍚楋紵锛佽繖鏄痵electKey鐨勯厤缃€傛墽琛屽畬insertSQL锛屽紑濮嬫墽琛屽緱鍒版渶缁堢殑绱㈠紩鍊笺€傞€氬父鍙閰嶇疆姝g‘锛岃繑鍥炲璞′腑鏈夊搴旂殑id瀛楁锛屽氨鍙互姝g‘鑾峰彇鍒拌繑鍥炲€笺€侾S锛氶棶棰樺氨鍦ㄨ繖閲岋紝浠樺摜鎵嬪啓鐨凪ybatis灞呯劧鍙繑鍥炰竴涓?锛?銆佸垎鏋愶細澶ч儴鍒嗙爺鍙戝皬浼欎即鍙兘娌℃湁鐪嬭繃Mybatis鐨勬簮鐮佽繘琛屽紓甯歌瘖鏂紝鎵€浠ュ彲鑳戒笉鐭ラ亾杩欓噷鍙戠敓浜嗕粈涔堛€傝繖閲屼粯鍝ョ粰澶у鐢讳釜鍥撅紝鍛婅瘔澶у鍒板簳鍙戠敓浜嗕粈涔堬紝浣垮緱杩斿洖缁撴灉涓?銆傘€侻ybatis鐨勫鐞嗚繃绋嬪彲浠ュ垎涓轰袱閮ㄥ垎锛屼竴閮ㄥ垎鏄В鏋愶紝涓€閮ㄥ垎鏄娇鐢ㄣ€傝В鏋愭椂锛岃В鏋愬嚭MapperXML涓殑insert鏍囩璇彞锛屽悓鏃惰В鏋恠electKey鏍囩銆傛渶鍚庤В鏋愬畬鎴愬悗锛屼娇鐢∕appedStatement鏄犲皠璇彞绫诲瓨鍌ㄨВ鏋愬嚭鐨勮鍙ヤ俊鎭€傚彲浠ヤ粠Configuration閰嶇疆椤逛腑鑾峰彇锛岀敤浜嶥efaultSqlSession涓殑鍚庣画鎿嶄綔銆傜劧鍚庤繖閲屾湁寰堥噸瑕佺殑涓€鐐癸紝灏辨槸鎵цinsert鐨勬椂鍊欙紝杩樺寘鍚簡涓€涓猶uery鎿嶄綔銆備篃灏辨槸璇达紝鎴戜滑浼氬湪涓€涓狪nsert涓寘鍚袱鏉℃墽琛岃鍙ャ€傚叧閿偣锛歜ug灏卞彂鐢熷湪杩欓噷锛屼负浠€涔堬紵鍥犱负涓€寮€濮嬫墽琛岃繖涓ゆ潯璇彞鐨勬椂鍊欙紝鍦ㄨ幏鍙栭摼鎺ョ殑鏃跺€欙紝姣忎竴涓兘鑾峰彇涓€涓柊鐨勯摼鎺ワ紝鎵€浠ヤ篃灏辨槸璇磇nsertxxx鍜宻electLAST_INSERT_ID()鍦ㄦ墽琛屼袱涓猚onnection杩炴帴鐨勬椂鍊欏叾瀹炴槸閿欒鐨勩€傛槸鐨勶紝鑾峰彇涓嶅埌鎻掑叆鍚庣殑绱㈠紩ID銆傚彧鏈夊湪涓€涓摼鎺ユ垨鑰呬竴涓簨鍔★紙涓€娆ommit锛変笅锛屾墠鏈変簨鍔$壒鎬э紝鎵嶈兘寰楀埌鎻掑叆鏁版嵁鍚庣殑鑷ID銆傚張鍥犱负杩欓儴鍒嗗厛鎵嬪啓JdbcTransaction瀹炵幇Transaction鎺ュ彛鑾峰彇杩炴帴锛屾瘡娆¢兘鏄柊寤轰竴涓摼鎺ワ紝浠g爜鍧楀涓嬶紱杩欓噷鐨勯摼鎺ヨ幏鍙栵紝涓€寮€濮嬬殑鏃跺€欙紝娌℃湁涓€寮€濮嬬殑ifnull鍒ゆ柇锛屾瘡娆¢兘鏄洿鎺ヨ幏鍙栭摼鎺ワ紝鎵€浠ヨ繖涓嶆槸涓€涓摼鎺ヤ笅鐨勪袱涓猻ql鎿嶄綔锛屾墍浠ヤ笉浼氳幏鍙栧埌姝g‘鐨勭粨鏋滐紝鏄浉褰撲簬鍙崟鐙墽琛孲ELECTLAST_INSERT_ID()锛屾墍浠ユ渶缁堟煡璇㈢粨鏋滀负0锛佷綘鍙互娴嬭瘯灏嗚繖鏉¤鍙ュ鍒跺埌SQL鏌ヨ宸ュ叿涓墽琛屻€?.闇囨儕锛氬悓鏍风殑鍧戰煒備絾鍏跺疄鍙湁杩欎箞涓€涓摼鎺ラ棶棰橈紝灏忓倕鎵嬪啓Spring涔熼亣鍒拌繃銆係pring鐨勪竴閮ㄥ垎鏄叧浜庝簨鍔″鐞嗙殑銆傚叾瀹炶繖浜涗簨鍔℃搷浣滀篃鏄疛DBC灏佽鎿嶄綔锛屼緷闈犱粠鏁版嵁婧愯幏鍙栫殑閾炬帴鏉ョ鐞嗕簨鍔°€傝€屾垜浠钩鏃朵娇鐢⊿pring缁撳悎Mybatis閰嶇疆鏁版嵁婧愮殑鏂瑰紡锛岄偅涔堟垜浠浣曞湪涓€涓簨鍔′笅鎿嶄綔澶氭潯SQL璇彞鏃跺緱鍒板悓涓€涓摼鎺ャ€傚洜涓轰粠涓婇潰鐨勷煈嗮煆绘渚嬩腑鎴戜滑鐭ラ亾锛屼繚璇佷簨鍔$殑鐗规€ч渶瑕佸湪鍚屼竴涓摼鎺ヤ笅锛屽嵆浣挎墽琛屽涓猄QL鎿嶄綔锛屼篃宸茬粡鐩稿綋浜庢瘡娆¢兘鑾峰彇涓€涓柊鐨凷ession銆備粠杩炴帴姹犱腑鑾峰彇涓€涓柊鐨勯摼鎺ワ紝浣嗘槸涓轰簡瀹炵幇浜嬪姟鐨勭壒鎬э紝鏃犺鏄墜鍔ㄧ殑杩樻槸娉ㄨВ鐨勶紝閮介渶瑕佸湪浜嬪姟鎿嶄綔涓嬬殑澶氭潯SQL涔嬪墠鍚姩浜嬪姟鎿嶄綔銆傚苟涓旇繖涓簨鍔$殑寮€鍚姩浣滃鐞嗕簡涓€浜涗簨鍔′紶鎾涓哄拰闅旂绾у埆闄愬埗銆傚叾瀹炴洿閲嶈鐨勬槸澶氭SQL鎵ц寰楀埌鐨勯摼鎺ラ渶瑕佺浉鍚屻€傚洜姝よ繖閲屽紩鍏hreadLocal鏄熀浜庡叾鍦ㄥ悓涓€涓嚎绋嬭繍琛屼笅淇濆瓨淇℃伅鐨勫悓姝ョ壒鎬с€傚叾瀹炶繖閲屼粠浜嬪姟涓幏鍙栫殑閾炬帴鍏跺疄鏄繚瀛樺湪TransactionSynchronizationManager#resources灞炴€т腑鐨勩€傝櫧鐒跺彧鏈夎繖涔堜竴灏忓潡鍐呭锛屼絾灏忎粯褰撳垵鎵嬪啓Spring鐨勬椂鍊欎篃鏄紡鎺変簡銆傜洿鍒版祴璇曠殑鏃跺€欐墠鍙戠幇閾炬帴鍙戠幇浜ゆ槗鎬绘槸涓嶆垚鍔熴€備竴寮€濮嬩互涓烘槸鏁翠釜鍒囬潰閫昏緫娌℃湁鍒囧叆鎴栬€呮槸鎴戠殑鎿嶄綔鏂规硶涓嶅銆傜洿鍒版垜涓€姝ユ妫€鏌ュ拰璋冭瘯浠g爜锛屽彂鐜版墽琛屽涓猄QL骞朵笉鏄幏鍙栧埌鍚屼竴涓摼鎺ワ紝鎵€浠ヤ氦鏄撴棤娉曠敓鏁堛€?.甯歌锛氫簨鍔″け璐ュ彲鑳藉氨鏄繖涔堜竴涓皬鐜妭鐨勯棶棰橈紝鏈夋椂鍊欎細寮曞彂涓€鍫嗗紓甯搞€傚鏋滄垜浠病鏈夌爺绌惰繃婧愮爜锛岄偅涔堟垜浠彲鑳戒笉鐭ラ亾杩欐牱鐨勯棶棰樻槸鎬庝箞鍙戠敓鐨勩€傚洜姝わ紝娣卞叆鐨勭爺绌跺拰鎺㈢储寰€寰€浼氳浣犳洿瀹规槗銆佹洿鐩存帴鍦拌В閲婁竴涓棶棰樸€傞偅涔堜綘璇达紝浜ゆ槗澶辫触鐨勫師鍥犳槸浠€涔堬紵-鍒嗕韩涓€浜涘父瑙佺殑銆傚鏋滈亣鍒板叾浠栦汉锛屽彲浠ュ彂鍒拌瘎璁哄尯鐪嬬湅銆傛暟鎹簱寮曟搸涓嶆敮鎸佷簨鍔★細杩欓噷浠ySQL涓轰緥锛屽叾MyISAM寮曟搸涓嶆敮鎸佷簨鍔℃搷浣滐紝InnoDB鏄敮鎸佷簨鍔$殑寮曟搸銆備竴鑸娇鐢↖nnoDB鏉ユ敮鎸佷簨鍔°€俬ttps://dev.mysql.com/doc/refman/8.0/en/storage-en...浠嶮ySQL5.5.5寮€濮嬮粯璁ょ殑瀛樺偍寮曟搸鏄細InnoDB锛屼箣鍓嶉粯璁ょ殑鏄細MyISAM锛屾墍浠ヨ繖涓繀椤绘槸鍊煎緱娉ㄦ剰鐨勬槸锛屽鏋滃簳灞傚紩鎿庝笉鏀寔浜嬪姟锛屼綘鍐嶆€庝箞鍋氫篃娌$敤銆傛柟娉曚笉鍏紑锛氭憳鑷猄pring瀹樻柟鏂囨。銆愪娇鐢ㄤ唬鐞嗘椂锛屽簲浠呭皢@Transactional娉ㄨВ搴旂敤浜庡叿鏈夊叕寮€鍙鎬х殑鏂规硶銆傚鏋滄偍浣跨敤@Transactional娉ㄩ噴瀵瑰彈淇濇姢鐨勩€佺鏈夌殑鎴栧寘鍙鐨勬柟娉曡繘琛屾敞閲婏紝鍒欎笉浼氬紩鍙戦敊璇紝浣嗘敞閲婄殑鏂规硶涓嶄細鏄剧ず宸查厤缃殑浜嬪姟璁剧疆銆傚鏋滈渶瑕佹敞瑙i潪public鏂规硶鍙互鑰冭檻浣跨敤AspectJ锛堣涓嬫枃锛塢@Transactional鍙兘鐢ㄥ湪public鏂规硶涓婏紝鍚﹀垯浜嬪姟涓嶄細澶辫触锛屽鏋滄兂鐢ㄥ湪闈瀙ublic鏂规硶涓婏紝鎮ㄥ彲浠ユ墦寮€AspectJ浠g悊妯″紡銆備笉鍙桽pring绠$悊锛?/@Service-杩欐槸琚敞閲婃帀鐨勭爺绌朵簡鏁版嵁搴撹矾鐢辩粍浠禓BeanpublicPlatformTransactionManagertransactionManager(DataSourcedataSource){returnnewDataSourceTransactionManager(dataSource);寮傚父琚悶娌′簡銆俢atch鍚庣洿鎺ュ悆鎺夛紝浜嬪姟寮傚父鏃犳硶鍥炴粴銆傚悓鏃讹紝閰嶇疆鐩稿簲鐨勫紓甯窣Transactional(rollbackFor=Exception.class)5.鎬荤粨锛氬涔犵粡楠屼腑寰堝鍍忚繖鏍风殑鎶€鏈棶棰橀兘鏉ヨ嚜浠樺摜瀵规簮鐮佺殑鐮旂┒銆備竴寮€濮嬮亣鍒伴棶棰樺氨鍘荤湅鐪嬫簮鐮侊紝铏界劧寰€寰€寰堥毦鐞嗘竻鏁翠釜閫昏緫锛屼絾涓€鐐圭偣鐨勭Н绱‘瀹炰細璁╁紑鍙戣€呭鎶€鏈殑鐞嗚В鏇村姞鎵庡疄銆傛墍浠ョ幇鍦ㄤ箣鎵€浠ユ墜鍐橲pring鍜孧ybatis锛屾槸甯屾湜閫氳繃姊崇悊杩欎簺鐭ヨ瘑锛屽涔犲鏉傜殑閫昏緫璁捐鏂规銆佽璁″師鍒欎互鍙婂浣曞湪澶嶆潅鍦烘櫙涓嬩娇鐢ㄨ璁℃ā寮忚В鍐抽棶棰樸€侾S锛氶€氬父鎴戜滑涓氬姟浠g爜鐨勫鏉傚害鏄緢闅捐揪鍒拌繖绉嶇▼搴︾殑锛屾墍浠ョ湅鍒扳€滃ぉ鈥濅箣鍚庯紝灏卞緢瀹规槗璁捐鎴戜滑浠ュ悗鎵挎帴鐨勪笟鍔′簡銆傚彟澶栧氨鏄鍚勭鎶€鏈粏鑺傜殑鎶婃帶锛屾妸鐩稿叧鐨勬妧鏈璁″簲鐢ㄥ埌涓€浜涘紑鍙戜笂锛屾瘮濡係pringBootStarter锛屼篃鏄繖浜涚粡楠岀殑绉疮銆傚彧鏈夎繖鏍风殑骞垮害銆侀珮搴︺€佹繁搴︼紝鎵嶈兘鐪熸鎻愰珮涓汉鐨勭爺鍙戣兘鍔涖€傝捣鏉ャ€侾S锛氫篃鏄湪鎶€鏈殑閬撹矾涓婅蛋寰楁洿杩滐紝鏃犺鏄珮绾у紑鍙戯紝杩樻槸鏋舵瀯甯堬紝杩樻槸CTO锛?/p>