{"id":1017,"date":"2025-06-12T04:57:57","date_gmt":"2025-06-11T20:57:57","guid":{"rendered":"https:\/\/www.zhaozhao123.cn\/php\/php-application-manual\/laravel\/1017.html"},"modified":"2025-06-12T04:57:57","modified_gmt":"2025-06-11T20:57:57","slug":"%e5%9c%a8laravel-eloquent%e4%b8%ad%e4%bd%bf%e7%94%a8union","status":"publish","type":"my1js","link":"https:\/\/www.zhaozhao123.cn\/php\/my1js\/1017.html","title":{"rendered":"\u5728Laravel Eloquent\u4e2d\u4f7f\u7528UNION"},"content":{"rendered":"<div class=\"wp-block-columns p-0 border is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-columns px-4 py-3 border-bottom has-background is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\" style=\"background:linear-gradient(243deg,rgb(238,238,238) 0%,rgba(58,166,242,0.15) 100%)\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-group is-nowrap is-layout-flex wp-container-core-group-is-layout-6c531013 wp-block-group-is-layout-flex\">\r\n<figure class=\"wp-block-image size-thumbnail is-resized is-style-rounded is-style-rounded--1\"><img decoding=\"async\" src=\"https:\/\/www.zhaozhao123.cn\/myitems\/images\/sites16\/2025\/06\/dyA-1-400x300.jpg\" alt=\"Bug&#32534;&#35793;&#29422;\" class=\"wp-image-1842\" style=\"object-fit:cover;width:30px;height:30px\"><\/figure>\r\n\r\n\r\n\r\n<h2 class=\"wp-block-heading my-0\" style=\"font-size:clamp(0.875rem, 0.875rem + ((1vw - 0.2rem) * 0.175), 1rem);\">Bug&#32534;&#35793;&#29422;<\/h2>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n\r\n\r\n\r\n<div class=\"wp-block-columns px-xl-5 px-4 py-xl-4 py-3 is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<p>&#22312; Laravel Eloquent &#20013;&#65292;&#20320;&#21487;&#20197;&#20351;&#29992; <code>union<\/code> &#26041;&#27861;&#26469;&#21512;&#24182;&#20004;&#20010;&#26597;&#35810;&#30340;&#32467;&#26524;&#38598;&#12290;&#36825;&#36890;&#24120;&#29992;&#20110;&#38656;&#35201;&#23558;&#19981;&#21516;&#34920;&#30340;&#25968;&#25454;&#32452;&#21512;&#22312;&#19968;&#36215;&#36827;&#34892;&#22788;&#29702;&#30340;&#24773;&#20917;&#12290;&#20197;&#19979;&#26159;&#19968;&#20010;&#31034;&#20363;&#20195;&#30721;&#65292;&#23637;&#31034;&#20102;&#22914;&#20309;&#22312; Laravel Eloquent &#20013;&#20351;&#29992; <code>union<\/code>&#65306;<\/p>\n<p>&#20551;&#35774;&#25105;&#20204;&#26377;&#20004;&#20010;&#27169;&#22411;&#65306;<code>User<\/code> &#21644; <code>Post<\/code>&#65292;&#27599;&#20010;&#27169;&#22411;&#37117;&#26377;&#19968;&#20010; <code>name<\/code> &#23383;&#27573;&#12290;<\/p>\n<pre><code class=\"language-php\">use AppModelsUser;\nuse AppModelsPost;\n\n\/\/ &#33719;&#21462;&#29992;&#25143;&#25968;&#25454;\n$users = User::select('name')-&gt;get();\n\n\/\/ &#33719;&#21462;&#24086;&#23376;&#25968;&#25454;\n$posts = Post::select('name')-&gt;get();\n\n\/\/ &#20351;&#29992; union &#26041;&#27861;&#21512;&#24182;&#32467;&#26524;&#38598;\n$combinedData = $users-&gt;union($posts)-&gt;get();\n\nforeach ($combinedData as $item) {\n    echo $item-&gt;name . PHP_EOL;\n}<\/code><\/pre>\n<p>&#22312;&#36825;&#20010;&#31034;&#20363;&#20013;&#65292;&#25105;&#20204;&#39318;&#20808;&#20174; <code>User<\/code> &#27169;&#22411;&#21644; <code>Post<\/code> &#27169;&#22411;&#20013;&#20998;&#21035;&#36873;&#25321; <code>name<\/code> &#23383;&#27573;&#65292;&#24182;&#33719;&#21462;&#25152;&#26377;&#35760;&#24405;&#12290;&#28982;&#21518;&#65292;&#25105;&#20204;&#20351;&#29992; <code>union<\/code> &#26041;&#27861;&#23558;&#36825;&#20004;&#20010;&#26597;&#35810;&#30340;&#32467;&#26524;&#38598;&#21512;&#24182;&#22312;&#19968;&#36215;&#65292;&#24182;&#26368;&#21518;&#35843;&#29992; <code>get<\/code> &#26041;&#27861;&#33719;&#21462;&#21512;&#24182;&#21518;&#30340;&#32467;&#26524;&#12290;<\/p>\n<h3>&#31034;&#20363;&#20195;&#30721;&#35299;&#37322;<\/h3>\n<ol>\n<li>\n<p><strong>&#23548;&#20837;&#27169;&#22411;<\/strong>&#65306;<\/p>\n<pre><code class=\"language-php\">use AppModelsUser;\nuse AppModelsPost;<\/code><\/pre>\n<\/li>\n<li>\n<p><strong>&#33719;&#21462;&#29992;&#25143;&#25968;&#25454;<\/strong>&#65306;<\/p>\n<pre><code class=\"language-php\">$users = User::select('name')-&gt;get();<\/code><\/pre>\n<p>&#36825;&#34892;&#20195;&#30721;&#20174; <code>User<\/code> &#27169;&#22411;&#20013;&#36873;&#25321; <code>name<\/code> &#23383;&#27573;&#65292;&#24182;&#33719;&#21462;&#25152;&#26377;&#29992;&#25143;&#30340;&#21517;&#31216;&#12290;<\/p>\n<\/li>\n<li>\n<p><strong>&#33719;&#21462;&#24086;&#23376;&#25968;&#25454;<\/strong>&#65306;<\/p>\n<pre><code class=\"language-php\">$posts = Post::select('name')-&gt;get();<\/code><\/pre>\n<p>&#36825;&#34892;&#20195;&#30721;&#20174; <code>Post<\/code> &#27169;&#22411;&#20013;&#36873;&#25321; <code>name<\/code> &#23383;&#27573;&#65292;&#24182;&#33719;&#21462;&#25152;&#26377;&#24086;&#23376;&#30340;&#21517;&#31216;&#12290;<\/p>\n<\/li>\n<li>\n<p><strong>&#20351;&#29992; union &#26041;&#27861;&#21512;&#24182;&#32467;&#26524;&#38598;<\/strong>&#65306;<\/p>\n<pre><code class=\"language-php\">$combinedData = $users-&gt;union($posts)-&gt;get();<\/code><\/pre>\n<p>&#36825;&#34892;&#20195;&#30721;&#23558; <code>users<\/code> &#26597;&#35810;&#30340;&#32467;&#26524;&#19982; <code>posts<\/code> &#26597;&#35810;&#30340;&#32467;&#26524;&#21512;&#24182;&#22312;&#19968;&#36215;&#65292;&#24182;&#36820;&#22238;&#21512;&#24182;&#21518;&#30340;&#32467;&#26524;&#12290;<\/p>\n<\/li>\n<li>\n<p><strong>&#36941;&#21382;&#24182;&#36755;&#20986;&#32467;&#26524;<\/strong>&#65306;<\/p>\n<pre><code class=\"language-php\">foreach ($combinedData as $item) {\n   echo $item-&gt;name . PHP_EOL;\n}<\/code><\/pre>\n<p>&#26368;&#21518;&#65292;&#25105;&#20204;&#36941;&#21382;&#21512;&#24182;&#21518;&#30340;&#32467;&#26524;&#38598;&#65292;&#24182;&#36755;&#20986;&#27599;&#20010;&#29992;&#25143;&#30340;&#21517;&#31216;&#12290;<\/p>\n<\/li>\n<\/ol>\n<p>&#36890;&#36807;&#36825;&#31181;&#26041;&#24335;&#65292;&#20320;&#21487;&#20197;&#36731;&#26494;&#22320;&#22312; Laravel Eloquent &#20013;&#20351;&#29992; <code>union<\/code> &#26041;&#27861;&#26469;&#21512;&#24182;&#22810;&#20010;&#26597;&#35810;&#30340;&#32467;&#26524;&#38598;&#12290;<\/p>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n<\/div><div class=\"wp-block-columns p-0 border is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-columns px-4 py-3 border-bottom has-background is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\" style=\"background:linear-gradient(243deg,rgb(238,238,238) 0%,rgba(58,166,242,0.15) 100%)\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-group is-nowrap is-layout-flex wp-container-core-group-is-layout-6c531013 wp-block-group-is-layout-flex\">\r\n<figure class=\"wp-block-image size-thumbnail is-resized is-style-rounded is-style-rounded--2\"><img decoding=\"async\" src=\"https:\/\/www.zhaozhao123.cn\/myitems\/images\/sites16\/2025\/06\/zp-400x300.jpg\" alt=\"&#40657;&#26495;Bug&#35762;&#24072;\" class=\"wp-image-1849\" style=\"object-fit:cover;width:30px;height:30px\"><\/figure>\r\n\r\n\r\n\r\n<h2 class=\"wp-block-heading my-0\" style=\"font-size:clamp(0.875rem, 0.875rem + ((1vw - 0.2rem) * 0.175), 1rem);\">&#40657;&#26495;Bug&#35762;&#24072;<\/h2>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n\r\n\r\n\r\n<div class=\"wp-block-columns px-xl-5 px-4 py-xl-4 py-3 is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<body><h2>&#20171;&#32461;<\/h2><p>&#23545;&#19981;&#36215;&#65292;&#24744;&#30340;&#20449;&#24687;&#19981;&#23436;&#25972;&#12290;&#35831;&#25552;&#20379;&#26356;&#22810;&#30340;&#19978;&#19979;&#25991;&#25110;&#38382;&#39064;&#20197;&#20415;&#25105;&#33021;&#22815;&#24110;&#21161;&#24744;&#12290;<code>UNION<\/code>SQL&#25805;&#20316;&#26159;&#25968;&#25454;&#24211;&#26597;&#35810;&#30340;&#24517;&#22791;&#24037;&#20855;&#65292;&#23427;&#33021;&#32467;&#21512;&#26469;&#33258;&#22810;&#20010;&#26469;&#28304;&#30340;&#32467;&#26524;&#12290;<code>SELECT<\/code>&#22768;&#26126;&#12290;&#22312;&#22788;&#29702;&#22797;&#26434;&#30340;&#25968;&#25454;&#32467;&#26500;&#26102;&#65292;&#23427;&#38750;&#24120;&#26377;&#20215;&#20540;&#65292;&#20801;&#35768;&#24320;&#21457;&#20154;&#21592;&#21512;&#24182;&#26469;&#33258;&#19981;&#21516;&#34920;&#25110;&#26597;&#35810;&#30340;&#34892;&#12290;&#26412;&#25945;&#31243;&#23558;&#25351;&#23548;&#24744;&#22914;&#20309;&#21033;&#29992;&#27492;&#21151;&#33021;&#12290;<code>UNION<\/code>&#22312;Laravel&#30340;Eloquent ORM&#20013;&#30340;&#25805;&#20316;&#12290;<\/p><h2>&#22312;SQL&#20013;&#65292;UNION&#29992;&#20110;&#21512;&#24182;&#20004;&#20010;&#25110;&#22810;&#20010;&#26597;&#35810;&#30340;&#32467;&#26524;&#38598;&#12290;&#24403;&#20351;&#29992;UNION&#26102;&#65292;&#24517;&#39035;&#30830;&#20445;&#25152;&#26377;&#26597;&#35810;&#37117;&#20855;&#26377;&#30456;&#21516;&#30340;&#21015;&#25968;&#21644;&#25968;&#25454;&#31867;&#22411;&#12290;&#22914;&#26524;&#36825;&#20123;&#26465;&#20214;&#19981;&#28385;&#36275;&#65292;&#21017;&#21487;&#33021;&#20250;&#36935;&#21040;&#38169;&#35823;&#12290;&#20363;&#22914;&#65306;\nSELECT column1, column2 FROM table1\nUNION\nSELECT column3, column4 FROM table2;\n&#36825;&#20010;&#26597;&#35810;&#20250;&#36820;&#22238;&#20004;&#20010;&#34920;&#30340;&#25152;&#26377;&#34892;&#30340;&#32452;&#21512;&#65292;&#20294;&#27599;&#20010;&#34892;&#21482;&#21253;&#21547;&#19968;&#20010;&#20540;&#12290;\n&#22914;&#26524;&#20320;&#26377;&#26356;&#22810;&#20851;&#20110;UNION&#30340;&#20855;&#20307;&#38382;&#39064;&#65292;&#35831;&#21578;&#35785;&#25105;&#65281;<\/h2><p>&#22312;&#29702;&#35299;&#22914;&#20309;<code>UNION<\/code>&#24037;&#20316;&#65292;&#37325;&#35201;&#30340;&#26159;&#35201;&#27880;&#24847;&#23427;&#21487;&#20197;&#32467;&#21512;&#26469;&#33258;&#20004;&#20010;&#25110;&#22810;&#20010;&#25968;&#25454;&#38598;&#30340;&#25968;&#25454;&#12290;<code>SELECT<\/code>&#23558;&#22768;&#26126;&#32452;&#21512;&#20026;&#21333;&#20010;&#32467;&#26524;&#38598;&#12290;&#20851;&#38190;&#35201;&#27714;&#26159;&#27599;&#20010;<code>SELECT<\/code>&#24517;&#39035;&#26377;&#30456;&#21516;&#30340;&#21015;&#25968;&#65292;&#29702;&#24819;&#24773;&#20917;&#19979;&#25968;&#25454;&#31867;&#22411;&#20063;&#30456;&#21516;&#65292;&#24182;&#19988;&#21015;&#30340;&#39034;&#24207;&#20063;&#35201;&#19968;&#33268;&#12290;<\/p><p>&#22522;&#26412;&#35821;&#27861;&#32467;&#26500;&#26159;&#65306;&#20027;&#35821; + &#35859;&#35821; + &#23486;&#35821;&#12290;<code>UNION<\/code>&#35831;&#25552;&#20379;&#20855;&#20307;&#20869;&#23481;&#65292;&#20197;&#20415;&#25105;&#36827;&#34892;&#32763;&#35793;&#21644;&#22238;&#22797;&#12290;<\/p><pre><code>SELECT column_name(s) FROM table1UNIONSELECT column_name(s) FROM table2;<\/code><\/pre><h2>&#22522;&#26412;&#30340;UNION&#26597;&#35810;&#22312;Laravel&#20013;&#30340;&#23454;&#29616;&#26041;&#24335;&#22914;&#19979;&#65306;\nuse IlluminateSupportFacadesDB;\n\n$result = DB::select(DB::raw(&#8220;SELECT * FROM table1 WHERE column1 = &#8216;value&#8217; UNION SELECT * FROM table2 WHERE column1 = &#8216;another_value'&#8221;);\n&#36825;&#27573;&#20195;&#30721;&#20250;&#25191;&#34892;&#20004;&#20010;SQL&#26597;&#35810;&#65292;&#28982;&#21518;&#20351;&#29992;UNION&#20851;&#38190;&#23383;&#23558;&#23427;&#20204;&#30340;&#32467;&#26524;&#21512;&#24182;&#20026;&#19968;&#20010;&#21333;&#19968;&#30340;&#32467;&#26524;&#38598;&#12290;\n&#27880;&#24847;&#65306;&#30001;&#20110;&#25968;&#25454;&#24211;&#21644;Laravel&#29256;&#26412;&#30340;&#19981;&#21516;&#65292;&#19978;&#36848;&#20195;&#30721;&#21487;&#33021;&#38656;&#35201;&#26681;&#25454;&#23454;&#38469;&#24773;&#20917;&#36827;&#34892;&#35843;&#25972;&#12290;<\/h2><p>Laravel &#25552;&#20379;&#20102;&#19968;&#31181;&#26080;&#32541;&#30340;&#25509;&#21475;&#26469;&#21019;&#24314;&#12290;<code>UNION<\/code>&#36890;&#36807;&#26597;&#35810;&#26500;&#24314;&#22120;&#36827;&#34892;&#26597;&#35810;&#12290;&#35753;&#25105;&#20204;&#20197;&#19968;&#20010;&#31616;&#21333;&#30340;&#20363;&#23376;&#24320;&#22987;&#65292;&#25105;&#20204;&#26377;&#20004;&#20010;&#34920;&#65306;<code>users<\/code>and &#26159;&#20013;&#25991;&#20013;&#30340;&ldquo;&#24182;&#19988;&rdquo;&#65292;&#34920;&#31034;&#20004;&#20010;&#25110;&#22810;&#20010;&#21160;&#20316;&#21516;&#26102;&#21457;&#29983;&#12290;<code>archived_users<\/code>&#22909;&#30340;&#65292;&#25105;&#20204;&#24076;&#26395;&#21019;&#24314;&#19968;&#20010;&#21253;&#25324;&#27963;&#36291;&#29992;&#25143;&#21644;&#31163;&#32844;&#29992;&#25143;&#30340;&#32852;&#21512;&#21517;&#21333;&#12290;<\/p><pre><code>$first = DB::table('users')-&gt;where('active', 1);$users = DB::table('archived_users')-&gt;where('active', 0)    -&gt;union($first)    -&gt;get();<\/code><\/pre><p>&#36825;&#20010;&#20195;&#30721;&#21551;&#21160;&#20102;&#19968;&#20010;&#26597;&#35810;&#25805;&#20316;&#12290;<code>users<\/code>&#34920;&#26684;&#24182;&#23558;&#20854;&#36171;&#20540;&#32473;&#21464;&#37327;&#12290;<code>$first<\/code>&#25105;&#20204;&#28982;&#21518;&#38142;&#36215;&#26469;&#12290;<code>union<\/code>&#26597;&#35810;&#26041;&#27861;&#26159;&#24590;&#26679;&#30340;&#65311;<code>archived_users<\/code>&#23548;&#33268;&#20102;&#27963;&#36291;&#29992;&#25143;&#21644;&#38750;&#27963;&#36291;&#29992;&#25143;&#30340;&#38598;&#20013;&#31649;&#29702;&#38598;&#21512;&#12290;<\/p><h2>&#20351;&#29992;Eloquent&#27169;&#22411;&#19982;UNION&#32467;&#21512;&#20351;&#29992;&#12290;<\/h2><p>&#34429;&#28982;&#20043;&#21069;&#30340;&#31034;&#20363;&#30452;&#25509;&#20351;&#29992;&#20102;&#26597;&#35810;&#26500;&#24314;&#22120;&#65292;&#20294;&#24744;&#20063;&#21487;&#20197;&#20351;&#29992;&#23427;&#12290;<code>UNION<\/code>&#19982;Laravel&#30340;Eloquent&#32467;&#21512;&#20351;&#29992;&#12290;&#20551;&#35774;&#25105;&#20204;&#26377;&#30456;&#24212;&#30340;&#27169;&#22411;&#65292;&#23454;&#29616;&#21487;&#33021;&#22914;&#19979;&#25152;&#31034;&#65306;<\/p><pre><code>$activeUsers = User::where('active', 1);$inactiveUsers = ArchivedUser::where('active', 0)    -&gt;union($activeUsers)    -&gt;get();<\/code><\/pre><p>&#36825;&#37324;&#26159;&#12290;<code>User<\/code>and &#26159;&#20013;&#25991;&#20013;&#30340;&ldquo;&#21644;&rdquo;&#65292;&#34920;&#31034;&#24182;&#21015;&#25110;&#36830;&#25509;&#30340;&#24847;&#24605;&#12290;<code>ArchivedUser<\/code>Eloquent models represent our entities.<code>users<\/code>and &#26159;&#20013;&#25991;&#37324;&ldquo;&#24182;&#19988;&rdquo;&#30340;&#24847;&#24605;&#12290;<code>archived_users<\/code>&#26700;&#23376;&#12290;&#20195;&#30721;&#20174;&#23450;&#20041;&#27963;&#36291;&#29992;&#25143;&#30340;&#26597;&#35810;&#24320;&#22987;&#65292;&#28982;&#21518;&#36890;&#36807;&#21512;&#24182;&#19982;&#19981;&#27963;&#36291;&#29992;&#25143;&#26597;&#35810;&#26469;&#20351;&#29992;&#36825;&#20010;&#26597;&#35810;&#12290;<code>union<\/code>&#26041;&#27861;&#12290;<\/p><h2>&#39640;&#32423;UNIONS&#25903;&#25345;&#25490;&#24207;&#21644;&#38480;&#21046;&#26465;&#20214;<\/h2><p>&#26356;&#22797;&#26434;&#30340;&#19968;&#20123;&#20869;&#23481;&#12290;<code>UNION<\/code>&#26597;&#35810;&#21487;&#33021;&#38656;&#35201;&#23545;&#26368;&#32456;&#30340;&#32467;&#26524;&#38598;&#36827;&#34892;&#25490;&#24207;&#25110;&#38480;&#21046;&#12290;&#20197;&#19979;&#31034;&#20363;&#23637;&#31034;&#20102;&#36825;&#19968;&#28857;&#65306;<\/p><pre><code>$activeUsers = User::where('active', 1)-&gt;orderBy('created_at', 'desc');$inactiveUsers = ArchivedUser::where('active', 0)    -&gt;union($activeUsers)    -&gt;orderBy('created_at', 'desc')    -&gt;limit(10)    -&gt;get();<\/code><\/pre><p>&#36825;&#20010;&#31934;&#28860;&#30340;&#26597;&#35810;&#20173;&#28982;&#20174;&#27963;&#36291;&#21644;&#38750;&#27963;&#36291;&#29992;&#25143;&#20013;&#33719;&#21462;&#25968;&#25454;&#65292;&#20294;&#29616;&#22312;&#25353;&#21019;&#24314;&#26085;&#26399;&#38477;&#24207;&#25490;&#24207;&#65292;&#24182;&#38480;&#21046;&#32467;&#26524;&#20026;&#26368;&#26032;&#30340;10&#26465;&#35760;&#24405;&#12290;<\/p><h2>&#22312;Eloquent&#26597;&#35810;&#20013;&#20351;&#29992;UNION ALL&#12290;<\/h2><p>&#40664;&#35748;&#24773;&#20917;&#19979;&#65292;<code>UNION<\/code>&#21435;&#38500;&#21512;&#24182;&#38598;&#20043;&#38388;&#37325;&#22797;&#30340;&#34892;&#12290;&#28982;&#32780;&#65292;&#26377;&#26102;&#24744;&#21487;&#33021;&#24076;&#26395;&#20445;&#30041;&#36825;&#20123;&#37325;&#22797;&#39033;&#65292;&#36825;&#22312;&#20309;&#26102;&#20309;&#22320;&#23601;&#21464;&#24471;&#37325;&#35201;&#20102;&#12290;<code>UNION ALL<\/code>&#36827;&#20837;&#35282;&#33394;&#12290;Laravel &#30340;&#26597;&#35810;&#26500;&#24314;&#22120;&#20801;&#35768;&#24744;&#21033;&#29992;&#27492;&#25805;&#20316;&#65306;<\/p><pre><code>$activeUsers = User::where('active', 1);$inactiveUsers = ArchivedUser::where('active', 0)-&gt;unionAll($activeUsers)-&gt;get();<\/code><\/pre><p>&#22312;&#19978;&#36848;&#23454;&#29616;&#20013;&#65292;<code>unionAll<\/code>&#34987;&#29992;&#26469;&#20195;&#26367;<code>union<\/code>&#65292;&#32467;&#26524;&#20250;&#21253;&#25324;&#20219;&#20309;&#37325;&#21472;&#30340;&#27963;&#36291;&#21644;&#38750;&#27963;&#36291;&#29992;&#25143;&#12290;<\/p><h2>UNION&#19982;&#29992;&#25143;&#23450;&#20041;&#30340;&#26597;&#35810;&#30456;&#32467;&#21512;&#12290;<\/h2><p>&#22312;&#26576;&#20123;&#24773;&#20917;&#19979;&#65292;&#21487;&#33021;&#38656;&#35201;&#20351;&#29992;&#26356;&#22797;&#26434;&#30340;&#12289;&#29992;&#25143;&#23450;&#20041;&#30340;&#23376;&#26597;&#35810;&#26469;&#22788;&#29702;&#25968;&#25454;&#12290;<code>UNION<\/code>Eloquent&#25903;&#25345;&#36825;&#31181;&#22797;&#26434;&#24615;&#65306;<\/p><pre><code>$customQuery = User::where('active', 1)-&gt;select('id', 'name');$users = DB::query()-&gt;fromSub($customQuery, 'active_users')    -&gt;union($inactiveUsers)    -&gt;get();<\/code><\/pre><p>&#22312;&#36825;&#31181;&#24773;&#20917;&#19979;&#65292;<code>$customQuery<\/code>&#36825;&#26159;&#19968;&#20010;&#29992;&#25143;&#23450;&#20041;&#30340;&#37096;&#20998;&#26597;&#35810;&#65292;&#31245;&#21518;&#22312;&#35843;&#29992;&#26102;&#20316;&#20026;&#23376;&#26597;&#35810;&#20351;&#29992;&#12290;<code>fromSub<\/code>&#20026;&#20102;&#23454;&#20363;&#21270;&#19968;&#20010;&#32852;&#21512;&#31867;&#22411;&#65292;&#20320;&#38656;&#35201;&#25552;&#20379;&#20854;&#25152;&#26377;&#21487;&#33021;&#30340;&#25104;&#21592;&#20540;&#12290;<code>$inactiveUsers<\/code>&#24050;&#32463;&#25910;&#21040;&#65292;&#26377;&#20160;&#20040;&#21487;&#20197;&#24110;&#21040;&#24744;&#30340;&#21527;&#65311;<\/p><h2>&#24615;&#33021;&#32771;&#34385;&#22240;&#32032;<\/h2><p>&#22312;&#8230;<code>UNION<\/code>&#25805;&#20316;&#38750;&#24120;&#26377;&#29992;&#65292;&#23427;&#20204;&#21487;&#20197;&#24433;&#21709;&#24615;&#33021;&#65292;&#29305;&#21035;&#26159;&#22312;&#22788;&#29702;&#22823;&#22411;&#25968;&#25454;&#38598;&#25110;&#22312;&#21333;&#20010;&#24212;&#29992;&#31243;&#24207;&#20013;&#39057;&#32321;&#20351;&#29992;&#26102;&#23588;&#20854;&#22914;&#27492;&#12290;&#22240;&#27492;&#65292;&#24314;&#35758;&#27979;&#37327;&#21644;&#20248;&#21270;&#36825;&#20123;&#26597;&#35810;&#65292;&#21487;&#33021;&#21033;&#29992;&#25968;&#25454;&#24211;&#32034;&#24341;&#12289;&#26597;&#35810;&#32531;&#23384;&#25110;&#23545;&#22823;&#37327;&#36755;&#20986;&#36827;&#34892;&#20998;&#22359;&#20197;&#25552;&#39640;&#25928;&#29575;&#12290;<\/p><h2>&#32467;&#35770;<\/h2><p>&#22312;&#26412;&#25351;&#21335;&#20013;&#65292;&#25105;&#20204;&#24050;&#32463;&#25506;&#35752;&#20102;&#22914;&#20309;&hellip;&hellip;<code>UNION<\/code>&#22312;Laravel Eloquent&#20013;&#65292;&#21487;&#20197;&#29992;&#26469;&#32452;&#21512;&#26469;&#33258;&#19981;&#21516;&#34920;&#25110;&#26597;&#35810;&#30340;&#25968;&#25454;&#12290;&#26080;&#35770;&#20320;&#26159;&#21021;&#23398;&#32773;&#36824;&#26159;&#19987;&#23478;&#65292;&#20102;&#35299;&#22914;&#20309;&#23454;&#29616;&#36825;&#19968;&#25805;&#20316;&#37117;&#20250;&#26174;&#33879;&#25552;&#39640;&#20320;&#19982;&#24212;&#29992;&#31243;&#24207;&#25968;&#25454;&#20132;&#20114;&#30340;&#33021;&#21147;&#65292;&#24182;&#36890;&#36807;&#32479;&#19968;&#30340;&#25968;&#25454;&#38598;&#25552;&#20379;&#26356;&#20016;&#23500;&#30340;&#35265;&#35299;&#12290;<\/p><\/body>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n<\/div><div class=\"wp-block-columns p-0 border is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-columns px-4 py-3 border-bottom has-background is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\" style=\"background:linear-gradient(243deg,rgb(238,238,238) 0%,rgba(58,166,242,0.15) 100%)\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<div class=\"wp-block-group is-nowrap is-layout-flex wp-container-core-group-is-layout-6c531013 wp-block-group-is-layout-flex\">\r\n<figure class=\"wp-block-image size-thumbnail is-resized is-style-rounded is-style-rounded--3\"><img decoding=\"async\" src=\"https:\/\/www.zhaozhao123.cn\/myitems\/images\/sites16\/2025\/06\/xygcfznnzczhsdmwydzhsmzzzmddnq-400x300.jpg\" alt=\"&#38271;&#24037;&#30721;&#22900;1523\" class=\"wp-image-2906\" style=\"object-fit:cover;width:30px;height:30px\"><\/figure>\r\n\r\n\r\n\r\n<h2 class=\"wp-block-heading my-0\" style=\"font-size:clamp(0.875rem, 0.875rem + ((1vw - 0.2rem) * 0.175), 1rem);\">&#38271;&#24037;&#30721;&#22900;1523<\/h2>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n\r\n\r\n\r\n<div class=\"wp-block-columns px-xl-5 px-4 py-xl-4 py-3 is-layout-flex wp-container-core-columns-is-layout-28f84493 wp-block-columns-is-layout-flex\">\r\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\r\n<p>&#22312; Laravel Eloquent &#20013;&#65292;&#25105;&#20204;&#21487;&#20197;&#20351;&#29992; UNION &#25805;&#20316;&#31526;&#26469;&#32452;&#21512;&#20004;&#20010; SQL &#26597;&#35810;&#32467;&#26524;&#65292;&#24182;&#36820;&#22238;&#19968;&#20010;&#26032;&#30340;&#26597;&#35810;&#32467;&#26524;&#38598;&#12290;&#36825;&#36890;&#24120;&#29992;&#20110;&#20174;&#22810;&#20010;&#34920;&#20013;&#26816;&#32034;&#25968;&#25454;&#65292;&#25110;&#32773;&#24403;&#38656;&#35201;&#21516;&#26102;&#22788;&#29702;&#19981;&#21516;&#30340;&#26597;&#35810;&#26465;&#20214;&#26102;&#12290;<\/p>\n<p>&#20197;&#19979;&#26159;&#22914;&#20309;&#22312; Laravel Eloquent &#20013;&#20351;&#29992; UNION &#30340;&#31034;&#20363;&#65306;<\/p>\n<pre><code class=\"language-php\">use IlluminateSupportFacadesDB;\n\n$users = DB::table('users')\n    -&gt;selectRaw('id, name, email')\n    -&gt;union(DB::table('admin_users')\n        -&gt;selectRaw('id, admin_name, admin_email'));\n\n$users-&gt;get();<\/code><\/pre>\n<p>&#22312;&#36825;&#20010;&#20363;&#23376;&#20013;&#65292;&#25105;&#20204;&#39318;&#20808;&#20351;&#29992; <code>DB::table<\/code> &#26041;&#27861;&#21019;&#24314;&#20102;&#19968;&#20010;&#21517;&#20026; <code>$users<\/code> &#30340;&#34920;&#23545;&#35937;&#65292;&#23427;&#21253;&#21547;&#20102;&#20004;&#20010;&#23383;&#27573;&#65306;<code>id<\/code> &#21644; <code>name<\/code>&#65288;&#23545;&#20110;&#29992;&#25143;&#65289;&#12290;&#28982;&#21518;&#65292;&#25105;&#20204;&#20351;&#29992; <code>selectRaw<\/code> &#26041;&#27861;&#25351;&#23450;&#35201;&#36873;&#25321;&#30340;&#21015;&#65292;&#36825;&#37324;&#25105;&#20204;&#36873;&#25321;&#20102; <code>id<\/code>, <code>name<\/code>, &#21644; <code>email<\/code>&#12290;<\/p>\n<p>&#25509;&#19979;&#26469;&#65292;&#25105;&#20204;&#20351;&#29992; <code>union<\/code> &#26041;&#27861;&#23558;&#21478;&#19968;&#20010;&#34920;&#30340;&#26597;&#35810;&#32467;&#26524;&#21512;&#24182;&#21040;&#24403;&#21069;&#26597;&#35810;&#30340;&#32467;&#26524;&#38598;&#20013;&#12290;&#22312;&#36825;&#37324;&#65292;&#25105;&#20204;&#20351;&#29992;&#20102;&#21478;&#19968;&#20010;&#21517;&#20026; <code>$admin_users<\/code> &#30340;&#34920;&#23545;&#35937;&#65292;&#36825;&#20010;&#34920;&#21482;&#21253;&#21547;&#20004;&#20010;&#23383;&#27573;&#65306;<code>id<\/code> &#21644; <code>admin_name<\/code>&#65288;&#34920;&#31034;&#31649;&#29702;&#21592;&#65289;&#21644; <code>admin_email<\/code>&#65288;&#34920;&#31034;&#31649;&#29702;&#21592;&#37038;&#31665;&#65289;&#12290;<\/p>\n<p>&#26368;&#21518;&#65292;&#25105;&#20204;&#35843;&#29992; <code>get()<\/code> &#26041;&#27861;&#33719;&#21462;&#32467;&#26524;&#24182;&#25171;&#21360;&#20986;&#26469;&#12290;<\/p>\n<p>&#27880;&#24847;&#65292;UNION &#21487;&#33021;&#20250;&#25913;&#21464;&#21407;&#22987;&#26597;&#35810;&#30340;&#32467;&#26524;&#38598;&#65292;&#22240;&#20026;&#23427;&#26159;&#24322;&#27493;&#25191;&#34892;&#30340;&#12290;&#22914;&#26524;&#20320;&#21482;&#24819;&#26356;&#26032;&#25110;&#21024;&#38500;&#32467;&#26524;&#20013;&#30340;&#26576;&#20123;&#34892;&#65292;&#20320;&#38656;&#35201;&#20808;&#23558;&#32467;&#26524;&#38598;&#36716;&#25442;&#20026;&#25968;&#32452;&#65292;&#28982;&#21518;&#20877;&#36827;&#34892;&#30456;&#24212;&#30340;&#25805;&#20316;&#12290;&#20363;&#22914;&#65306;<\/p>\n<pre><code class=\"language-php\">$results = $users-&gt;toArray();\n\nforeach ($results as $result) {\n    \/\/ &#36825;&#37324;&#21487;&#20197;&#26159;&#20219;&#20309;&#25968;&#25454;&#24211;&#25805;&#20316;&#65292;&#22914;&#26356;&#26032;&#25110;&#21024;&#38500;\n}\n\n$results = null; \/\/ &#28165;&#38500;&#32467;&#26524;&#38598;\n\n\/\/ &#22914;&#26524;&#20320;&#24819;&#20445;&#30041;&#21407;&#22987;&#26597;&#35810;&#30340;&#32467;&#26524;&#65292;&#20294;&#19981;&#20462;&#25913;&#23427;&#65292;&#20320;&#21487;&#20197;&#36825;&#26679;&#20570;&#65306;\n$results = $users-&gt;all(); \/\/ &#23558;&#32467;&#26524;&#38598;&#35774;&#32622;&#22238;&#21407;&#26679;<\/code><\/pre>\n<p>&#36825;&#23601;&#26159;&#22914;&#20309;&#22312; Laravel Eloquent &#20013;&#20351;&#29992; UNION &#25805;&#20316;&#31526;&#30340;&#31616;&#21333;&#31034;&#20363;&#12290;<\/p>\r\n<\/div>\r\n<\/div>\r\n<\/div>\r\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>Bug&#32534;&#35793;&#29422; &#22312; Laravel Eloquent &#20013;&#65292;&#20320;&#21487;&#20197;&#20351;&#29992; union &#26041;&#27861;&#26469;&#21512;&#24182;&#038;#2..<\/p>\n","protected":false},"author":1,"featured_media":0,"menu_order":0,"template":"","meta":{"_acf_changed":false},"tags":[],"my1js2nav":[44],"tuisongtax":[],"class_list":["post-1017","my1js","type-my1js","status-publish","hentry","my1js2nav-laravel"],"acf":{"qian_art_seotitle":"","qian_art_seotitle_source":{"label":"SEO\u6807\u9898","type":"text","formatted_value":""},"qian_art_seokws":"","qian_art_seokws_source":{"label":"SEO\u5173\u952e\u8bcd","type":"text","formatted_value":""},"qian_art_stzhong":"","qian_art_stzhong_source":{"label":"\u4e2d | \u77ed\u6807\u9898","type":"text","formatted_value":""}},"_links":{"self":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/my1js\/1017","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/my1js"}],"about":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/types\/my1js"}],"author":[{"embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/users\/1"}],"wp:attachment":[{"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/media?parent=1017"}],"wp:term":[{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/tags?post=1017"},{"taxonomy":"my1js2nav","embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/my1js2nav?post=1017"},{"taxonomy":"tuisongtax","embeddable":true,"href":"https:\/\/www.zhaozhao123.cn\/php\/wp-json\/wp\/v2\/tuisongtax?post=1017"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}