sql数据库多表查询(sql数据库多表查询示例)

sql数据库多表查询(sql数据库多表查询示例),第1张

可以有两种处理方法,1、两表先合并,后求和

select日期,sum(数值)as数值from

(select日期,金额as数值fromA表

unionall

select日期,数量as数值fromB表)

groupby日期

2、先求和后合并,再求和

select日期,sum(数值)as数值from

(select日期,sum(金额)as数值fromA表groupby日期

unionall

select日期,sum(数量)as数值fromB表groupby日期)

groupby日期

对于“如果要实现总和的相乘、相除,或者相减得话,应该怎么写呢?”,你得提出明确需求,那后才能设计。

如果是相乘、相除,或者相减,得有条件,还像上面,用日期关联,A表-B表,A表求和:select日期,sum(金额)as数值fromA表groupby日期

B表求和:select日期,sum(数量)as数值fromB表groupby日期

在执行A表-B表时,由于用日期关联,则某一日期对应的记录可能会产生三种情况:A表B表都有;A表有B表无;A表无B表有。

1、需要先找出所有日期,select日期fromA表

union

select日期fromB表

2、对于A表中所有数据以上表中日期为依据构造所有相关日期数据,如果有日期数据,则为原数据,否则为0。

selecta日期as日期,casewhenb数值isNULLthenb数值else0endas数值

from

(select日期fromA表

union

select日期fromB表)a

leftjoin

(select日期,sum(金额)as数值fromA表groupby日期)b

ona日期=b日期

3、同样对于B表也如此。

4、2表相减即得。

selecta3日期as日期,a3数值-b3数值as数值

from

(

selecta1日期as日期,casewhenb1数值isNULLthenb1数值else0endas数值

from

(select日期fromA表

union

select日期fromB表)a1

leftjoin

(select日期,sum(金额)as数值fromA表groupby日期)b1

ona1日期=b1日期

)a3,(

selecta2日期as日期,casewhenb2数值isNULLthenb2数值else0endas数值

from

(select日期fromA表

union

select日期fromB表)a2

leftjoin

(select日期,sum(金额)as数值fromB表groupby日期)b2

ona2日期=b2日期

)b3

wherea3日期=b3日期

当然,以上只是一种方法,还有其他方法也可以实现,尽供参考。

枚举用户表名

查询系统表内容 ,查数据库里的系统表,里面记录了所有的表名

换有种方法

frmtxtSQL = "select distinct kucunkucun_no,dm_wzlb,kucunckdm,kucunwzdm,dm_wzmc,kucunsl,dm_wzrkj,kucuntotal_je,rukumxgfdm,kucundbsl,kucunbs,kucunsj,kucunupdate_date,rukumxbz from kucun inner join dm_wz on dm_wzdm=kucunwzdm inner join rukumx on rukumxwzdm=kucunwzdm

这个写的比较乱,你可以参考

方法3

用个存储过程来搞定,在sysobjects系统表中可以查询到数据库中所有的表名。

TABLE 语句

具体语法:TABLE table_name [ORDER BY column_name] [LIMIT number [OFFSET number]]

其实从语法上看,可以排序,也可以过滤记录集,不过比较简单,没有 SELECT 那么强大。

示例 1

简单的建一张很小的表 y1,记录数为 10 条。表 t1,插入 10 条记录

mysql-(ytt/3305)->create table t1 (r1 int,r2 int);

Query OK, 0 rows affected (002 sec)

mysql-(ytt/3305)->insert into t1

with recursive aa(a,b) as (

select 1,1

union all

select a+1,ceil(rand()20) from aa where a < 10

) select from aa;

Query OK, 10 rows affected (000 sec)

Records: 10  Duplicates: 0  Warnings: 0

简单全表扫描mysql-(ytt/3305)->select from t1;+------+------+| r1   | r2   |+------+------+|    1 |    1 ||    2 |    9 ||    3 |    9 ||    4 |   17 ||    5 |   17 ||    6 |   16 ||    7 |    6 ||    8 |    1 ||    9 |   10 ||   10 |    3 |+------+------+10 rows in set (000 sec)

TABLE 结果mysql-(ytt/3305)->table t1;+------+------+| r1   | r2   |+------+------+|    1 |    1 ||    2 |    9 ||    3 |    9 ||    4 |   17 ||    5 |   17 ||    6 |   16 ||    7 |    6 ||    8 |    1 ||    9 |   10 ||   10 |    3 |+------+------+10 rows in set (000 sec)

看下 table 的执行计划mysql-(ytt/3305)->explain table t1 order by r1 limit 2\G 1 row           id: 1  select_type: SIMPLE        table: t1   partitions: NULL         type: ALLpossible_keys: NULL          key: NULL      key_len: NULL          ref: NULL         rows: 10     filtered: 10000        Extra: Using filesort1 row in set, 1 warning (000 sec)

其实可以看到 TABLE 内部被 MySQL 转换为 SELECT 了。mysql-(ytt/3305)->show warnings\G 1 row  Level: Note   Code: 1003Message: / select#1 / select `ytt``t1``r1` AS `r1`,`ytt``t1``r2` AS `r2` from `ytt``t1` order by `ytt``t1``r1` limit 21 row in set (000 sec)

那其实从上面简单的例子可以看到 TABLE 在内部被转成了普通的 SELECT 来处理。示例 2应用于子查询里的子表。这里要注意,内表的字段数量必须和外表过滤的字段数量一致。克隆表 t1 结构mysql-(ytt/3305)->create table t2 like t1;Query OK, 0 rows affected (002 sec)

克隆表 t1 数据mysql-(ytt/3305)->insert into t2 table t1;Query OK, 10 rows affected (000 sec)Records: 10  Duplicates: 0  Warnings: 0

table t1 被当做内表,表 t1 有两个字段,必须同时满足 t2 检索时过滤的字段也是两个。mysql-(ytt/3305)->select from t2 where (r1,r2) in (table t1);+------+------+| r1   | r2   |+------+------+|    1 |    1 ||    2 |    9 ||    3 |    9 ||    4 |   17 ||    5 |   17 ||    6 |   16 ||    7 |    6 ||    8 |    1 ||    9 |   10 ||   10 |    3 |+------+------+10 rows in set (000 sec)

注意:这里如果过滤的字段数量和子表数量不一致,则会报错。

这个主要是看你用的哪个数据库了\x0d\不同的数据库有差异。\x0d\在mysql和oracle里面用如下方法最简单\x0d\select from table LIMIT 10,100;\x0d\\x0d\而在sqlserver中由于不支持limit只用其他方法啦:\x0d\当此表有主键时:\x0d\select top 100 from 表 where 主键 not in(select top 10 主键 from 表) \x0d\如果表中无主键:\x0d\可以用临时表,加标识字段解决这里的x,y可以用变量 \x0d\select id=identity(int,1,1), into #tb from 表 \x0d\select from #tb where id between 10 and 100

直接执行一下语句,即可批量替换数据库中的内容

update

表名

set

字段名=replace(字段名,"e16sucaicom","d16sucaicom")

其中e16suaicom

为原数据库内容,d16sucaicom为新内容,即替换后的内容。

sql查询一个表中某几列数据语法:

1、SELECT 列名称1、列名称2列名称n FROM 表名称 WHERE 列 运算符 值;

2、SELECT from 表名称 where 列 运算符 值(列 运算符 值,这个可以是多个,中间用and隔开)。

解析:使用sql查询时,作为查询的筛选限制条件,只需要对有限制要求的字段使用where进行限制即可,无需对非限制要求的字段进行特别限制。

所以你的语句可以修改为"select from test1 where id=‘2’;"就可以了。其中,你原语句中的name=全部和age=全部,属于多余的,如果不对name和age字段做任何限制的话,sql本身就是会查询全部name和age,而无需你另外加设条件。

再比如你这样写:“select from test1;”在不加任何where条件的情况下,这个sql查询本身就是查询全部数据。而当加入id='2'之后,就限制了只能返回id值是2的某一条或者多条数据。

扩展资料:

在SQL查询表中数据时,最常用的就是有条件查询,这就需要经常用到where子句对查询的内容做某些条件限制,整理部分常用的查询条件语句的使用,如下:

通过几个例子来加深一下对上表各查询条件使用的理解:

1、查询计算机科学系全体学生的名单;

SELECT Sname FROM StudentWHERE Sdept='CS';

2、查询所有年龄在20岁以下的学生姓名及其年龄;

SELECT Sname,Sage FROM StudentWHERE Sage<20;

3、查询考试成绩不合格的学生的学号;

SELECT DISTINCT Sno FROM SCWHERE Grade<60;

4、查询年龄在20~23岁之间的学生的姓名、系别和年龄;

SELECT Sname,Sdept,Sage FROM Student WHERE Sage BETWEEN 20 AND 23;

5、查询年龄在20~23岁之间的学生的姓名、系别和年龄;

SELECT Sname,Sdept,Sage FROM StudentWHERE Sage NOT BETWEEN 20 AND 23;

6、查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名、系别和年龄。

SELECT Sname,Ssex FROM Student WHERE Sdept IN('CS','MA','IS')。

以上就是关于sql数据库多表查询(sql数据库多表查询示例)全部的内容,包括:sql数据库多表查询(sql数据库多表查询示例)、sql 查询整个数据库里面每个表有多少条数据。、怎样用SQL语句查询一个数据库中的所有表等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9539455.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存