在MySQL中同时查找两张表中的数据的示例

 更新时间:2015年07月07日 11:58:54   投稿:goldensun  
这篇文章主要介绍了在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-被提取的行不存在。

相关文章

  • MYSQL插入处理重复键值的几种方法

    MYSQL插入处理重复键值的几种方法

    当unique列在一个UNIQUE键上插入包含重复值的记录时,默认insert的时候会报1062错误,MYSQL有三种不同的处理方法,下面我们分别介绍。
    2012-09-09
  • MySQL文本文件导入及批处理模式应用说明

    MySQL文本文件导入及批处理模式应用说明

    MySQL文本文件导入及批处理模式应用说明,需要的朋友可以参考下。
    2011-09-09
  • php后台经常提示无法连接mysql 刷新后又可以访问的解决方法

    php后台经常提示无法连接mysql 刷新后又可以访问的解决方法

    这几天有一台MySQL数据库服务器出现了频繁的掉线情况,通过排查,并没有排查出哪个网站被攻击,百思不得其解中的时候,群里有个朋友说是因为微软KB967723造成的,网上搜索了一下,果然很多人都是这样的问题,都是windows系统下安装的MySQL造成的
    2011-05-05
  • Mysql的longblob字段插入数据问题解决

    Mysql的longblob字段插入数据问题解决

    在使用mysql的过程中,有个问题就是mysql的优化,mysql中longblob字段在5.5版本中默认的为1M,需要解决问题的朋友可以参考下
    2014-01-01
  • mysql使用left join连接出现重复问题的记录

    mysql使用left join连接出现重复问题的记录

    这篇文章主要介绍了mysql使用left join连接出现重复问题的记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • MLSQL编译时权限控制示例详解

    MLSQL编译时权限控制示例详解

    这篇文章主要给大家介绍了关于MLSQL编译时权限控制的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • MySQL中InnoDB的间隙锁问题

    MySQL中InnoDB的间隙锁问题

    这篇文章主要介绍了MySQL中InnoDB的间隙锁问题,提醒用户注意死锁情况,需要的朋友可以参考下
    2015-07-07
  • Mysql 直接查询存储的Json字符串中的数据

    Mysql 直接查询存储的Json字符串中的数据

    本文主要介绍了Mysql直接查询存储的Json字符串中的数据,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Mysql事务索引知识汇总

    Mysql事务索引知识汇总

    这篇文章主要介绍了Mysql事务索引知识汇总,mysql事务是用于处理操作量大、复杂性高的数据,索引能加快数据库的查询速度并高效获取指定的数据,下文相关详细内容,需要的小伙伴可以参考一下
    2022-03-03
  • mysql建表报错:invalid default value for 'date'的解决方法

    mysql建表报错:invalid default value for 'date'的解决方

    最近遇到一个这样的问题,出现了invalid default value for 'end_date'错误,所以下面这篇文章主要给大家介绍了关于mysql建表报错:invalid default value for 'date'的解决方法,需要的朋友可以参考下
    2022-12-12

最新评论