mysql】mysql 合并sql,除了用UNION ALL 合并查询结果还有其他方式吗?

2021-02-25 19:28发布

4条回答
叽哩哇啦
2楼 · 2021-02-26 09:47

主要有两种:

    UNION ALL:对于mysql数据库,合并结果主要有UNION ALL 合并结果且不去除重复数据;

     UNION : 合并结果集并保留重复数据。

除此之外,如果需要合并结果集可以通过临时表的形式,将需要合并的数据先放入临时表,在操作。


Uzi
3楼 · 2021-03-09 09:40

1:使用联合查询:内连接,外连接
2:使用视图,将查询结果或两个表格加入视图
3:可以使用create newTable as select ..........(查询数据语句)将所有的查询结果存入一张新表

studentaaa
4楼 · 2021-03-19 07:47

合并查询方式总结:


CREATE TABLE `t_book` (

  `id` int(11) NOT NULL AUTO_INCREMENT,

  `bookName` varchar(20) DEFAULT NULL,

  `price` decimal(6,2) DEFAULT NULL,

  `author` varchar(20) DEFAULT NULL,

  `bookTypeId` int(11) DEFAULT NULL,

  PRIMARY KEY (`id`)

);

 

insert  into `t_book`(`id`,`bookName`,`price`,`author`,`bookTypeId`) values (1,'Java编程思想','100.00','埃史尔',1),(2,'Java从入门到精通','80.00','李钟尉',1),(3,'三剑客','70.00','大仲马',2),(4,'生理学(第二版)','24.00','刘先国',4);

 

CREATE TABLE `t_booktype` (

  `id` int(11) NOT NULL AUTO_INCREMENT,

  `bookTypeName` varchar(20) DEFAULT NULL,

  PRIMARY KEY (`id`)

);

 

insert  into `t_booktype`(`id`,`bookTypeName`) values (1,'计算机类'),(2,'文学类'),(3,'教育类');

合并查询项:


查询t_book中所有id

SELECT id FROM t_book;

 

查询t_booktype中所有id

SELECT id FROM t_booktype;

 

将两个查询结果合并,去除重复项

SELECT id FROM t_book UNION SELECT id FROM t_booktype;

 

将两个查询结果合并,不去除重复项

SELECT id FROM t_book UNION ALL SELECT id FROM t_booktype;

给表和字段取别名:


在t_book中查询id=1的记录

SELECT * FROM t_book WHERE id=1;

 

给t_book取个别名t

SELECT * FROM t_book t WHERE t.id=1;

 

在t_book中查询id=1的书名

SELECT t.bookName FROM t_book t WHERE t.id=1;

 

给字段t.bookName取个别名bName 

SELECT t.bookName bName FROM t_book t WHERE t.id=1;

相关问题推荐

  • 回答 5

    MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL的版本:针对不同的用户,MySQL分为两种不同的版本:MySQL Community Server社区版本,免费,但是Mysql不提供...

  • mysql安装步骤mysql 2022-05-07 18:01
    回答 2

    mysql安装需要先使用yum安装mysql数据库的软件包 ;然后启动数据库服务并运行mysql_secure_installation去除安全隐患,最后登录数据库,便可完成安装

  • 回答 5

    1.查看所有数据库showdatabases;2.查看当前使用的数据库selectdatabase();3.查看数据库使用端口showvariableslike'port';4.查看数据库编码showvariableslike‘%char%’;character_set_client 为客户端编码方式; character_set_connection 为建立连接...

  • 回答 5

    CREATE TABLE IF NOT EXISTS `runoob_tbl`(    `runoob_id` INT UNSIGNED AUTO_INCREMENT,    `runoob_title` VARCHAR(100) NOT NULL,    `runoob_author` VARCHAR(40) NOT NULL,    `submission_date` DATE,    PRI...

  • 回答 5

    在常规里面设置成utf-8

  • 回答 10

    首先是我们将鼠标移动到如下图所示的计算机的图标上,点击右键,选择管理。然后我们点击如下图界面中的服务和应用程序。接下来可以看到它下面有一个我们的目标——服务。服务的话它是按字母排列的,我们往下拉,找到Mysql服务。此时可以看到它是一个手动启动...

  • 回答 7

    有一些软件包无法被安装。如果您用的是 unstable 发行版,这也许是因为系统无法达到您要求的状态造成的。该版本中可能会有一些您需要的软件包尚未被创建或是它们已被从新到(Incoming)目录移出。下列信息可能会对解决问题有所帮助:下列软件包有未满足的依赖关...

  • 回答 20

    1. MySQL Community Server 社区版本,开源免费,但不提供官方技术支持。2. MySQL Enterprise Edition 企业版本,需付费,可以试用30天。3. MySQL Cluster 集群版,开源免费。可将几个MySQL Server封装成一个Server。4. MySQL Cluster CGE 高级集群版,需付费...

  • 回答 8

    mysql创建外键要求比较严格,严格到有时候你找不到到底哪里错了。1.检查你的表是不是都是INNodb类型的,只有这种类型才可以创建外键。2.检查字段名是不是有错误。3.检查字段类型,最好一样。4.比较隐蔽,检查字符集,为了迁移和使用的方便,尽量使用UTF85.上...

  • 回答 2

    1、请查看数据库的存储引擎,全文索引只支持MyISAM表。2、mysql默认对全文检索有单词的字符限制:ft_max_word_len 84,ft_min_word_len 43、MYSQL 全文索引是实现不了like  的效果,只能按单词来查询...

  • 回答 3

    这个最大4g应该是和是否是32位系统无关。

  • 回答 9

    第一种叫外连接 处在join前面的表会全部选择出来,你自己去百度下 说不清第二中就是多表连接,进行笛卡尔积运算自己那拿表去实践 你很快就会明白

  • 回答 4

    一定要卸载干净!!! 1. 在控制面板将mysql管理软件卸载掉 2. 删除两个安装文件,如果没有修改安装路径的默认路径如下1)C:\Program Files  有一个mysql安装目录 ,将整个目录删除 2)另外一个安装路径是一个隐藏文件夹下的mysql目录将隐藏的文件显示...

  • 回答 6

    事实上MySQL 能承受的数据量的多少主要和数据表的结构有关,并不是一个固定的数值。表的结构简单,则能承受的数据量相对比结构复杂时大些。据D.V.B 团队以及Cmshelp 团队做CMS 系统评测时的结果来看,MySQL单表大约在2千万条记录(4G)下能够良好运行,经过数...

  • 回答 5

    事实上MySQL 能承受的数据量的多少主要和数据表的结构有关,并不是一个固定的数值。表的结构简单,则能承受的数据量相对比结构复杂时大些。据D.V.B 团队以及Cmshelp 团队做CMS 系统评测时的结果来看,MySQL单表大约在2千万条记录(4G)下能够良好运行,经过数...

  • 回答 6

    mysql哪个版本比较稳定MySQL的选择要取决于用途的,mysql5.5或者5.7 的版本,网上资源较多mysql的版本如下:1. MySQL Community Server 社区版本,开源免费,但不提供官方技术支持。2. MySQL Enterprise Edition 企业版本,需付费,可以试用30天。3. MySQL C...

没有解决我的问题,去提问