程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 在MySQL中同時查找兩張表中的數據的示例

在MySQL中同時查找兩張表中的數據的示例

編輯:關於MYSQL數據庫

這個例子裡面我們從兩個表中取出頭兩行,然後合並到一個表中。

  在現實中我們常常會遇到這樣的情況,在一個數據庫中存在兩個表,假設表1儲存著公司個產品本季度銷售信息,表2儲存著公司本季度欠款金額情況。在一個頁面中我們想把這兩個信息顯示出來。通常的做法是在程序中進行兩次SQL查詢,返回兩個結果集,在分別顯示出來,非常麻煩。

  下面是實現這個功能的代碼:

  

CREATE PROCEDURE test

  AS

   SET NOCOUNT ON --指示存儲過程不返回查詢影響的行數

   DECLARE @col1c varchar(20),@col2c varchar(20), @index int

   SET @index = 1

   CREATE TABLE #tmptbl --創建一個臨時表,用於儲存我們的結果

   (

    colID int IDENTITY(1,1) PRIMARY KEY CLUSTERED,

    col1 varchar(20),

   col2 varchar(20)

   )

   DECLARE cur1 CURSOR FOR SELECT TOP 2 customerid FROM orders

   DECLARE cur2 CURSOR FOR SELECT TOP 2 regiondescription FROM region

   OPEN cur1

   OPEN cur2

   FETCH cur2 INTO @col2c

   FETCH cur1 INTO @col1c

   WHILE @@FETCH_STATUS = 0

    BEGIN

    INSERT INTO #tmptbl (col1, col2) VALUES (@col1c, @col2c)

    FETCH NEXT FROM cur1 INTO @col1c

    FETCH NEXT FROM cur2 INTO @col2c

    END

   CLOSE cur1

   CLOSE cur2

   DEALLOCATE cur1

   DEALLOCATE cur2

   SELECT * FROM #tmptbl

   DROP TABLE #tmptbl

  GO

  說明:

  @@FETCH_STATUS,返回被fetch語句執行的最後游標狀態。

  返回值:0-FETCH語句執行成功

      1-FETCH語句失敗,或此行不再結果集中。

      2-被提取的行不存在。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved