插入数据
数据插入
INSERT是用来插入行到数据库表的。插入可以用几种方式使用:
- 插入完整的行
- 插入行的一部分
- 插入多行
- 插入某些查询的结果
插入完整的行
INSERT INTO customers
VALUES (NULL,'PeP E.LaPew','100 Main Street','Los Angeles','CA','90046','USA',NULL,NULL);
:articulated_lorry:INSERT语句一般是不会产生输出的。
虽然上面的语法很简单但是不安全。他是很依赖表中列的定义次序,并且还依赖于其次序容易获得的信息。即使你能得到这种信息,你也不能保证下一次表结构变动后各个项保持完全相同的次序。
所以我们这样写:
INSERT INTO customers(cust_name,cust_address,cust_city,cust_state,cust_zip,cust_country,cust_contact,cust_email)
VALUES ('PeP E.LaPew','100 Main Street','Los Angeles','CA','90046','USA',NULL,NULL);
所以你最好就写上面这种。
:alarm_clock:但是不管那种INSERT语句都必须给出values的正确数目。如果不提供列名,则必须给每个表列提供提供一个值。如果提供列名,则必须对每个列出的列一个值。如果不这样,你是插入不成功。
:alarm_clock:使用上面这种语法,你是可以省略一些列的,省略的列需要满足这些特点:
- 该列定义为允许null的值
- 在表的定义中给出默认值。
插入多个行
INSERT可以插入一行到一个表中。但是你如果想插入多个行怎么办呢?其实就是使用多条INSERT语句,但是你可以一次性提交,用;分好隔开就好了。
INSERT INTO 表名(列名1,列名1)
VALUES (信息1,信息1);
INSERT INTO 表名(列名2,列名2)
VALUES (信息2,信息2);
或者如果列名相同,你还可以这样:
INSERT INTO 表名(列名1,列名1)
VALUES (信息1,信息1),
VALUES (信息2,信息2);
插入检索出的数据
INSERT还有一个很厉害的功能,他可以将一条SELECT语句的结果插入表中。这就是所谓的INSERT SELECT 。
例:我们从表2 的内容要复制到表1.
INSERT INTO 表1(列名1,列名2,列名3)
SELECT 列名1,列名2,列名3 FROM 表2;
有一个你需要注意的问题,就是虽然你看我写的列名是对应相等的,但是,是没这个必要相等的,mysql只管把对应位置的给你插入进去就好,它不管上下列名相同与否。
还有就是,对于像cust_id 这种你没办法保证表1表2不重复的列,你就可以省略这一列,让系统去生成id就好。
组合查询
组合查询
MySQL也允许执行多个查询(多条SELECT语句),并将结果作为单个查询结果集返回。这些组合查询通常称为并或复合查询。
创建组合查询
可以使用union操作符来组合数条SQL查询。利用union,可给出多条SELECT语句,将他们的结果组合成单个结果集。
使用union
union的使用其实是很简单的,所需要你做的就是给出每条SELECT语句,在各条语句之间放上关键字union。
:ice_cream:你比如说你像找价格小于等于5的所有物品,还想找供应商是1001和1002生产的所有物品,当然你写两个SELECT语句必然能解决这一问题,但是那就不是一个结果集了呀,所以你可以使用union。
SELECT vend_id ,prod_id,prod_price
FROM products
WHERE prod_price <= 5
UNION
SELECT vend_id ,prod_id,prod_price
FROM products
WHERE vend_id IN (1001,1002);
呐。union的使用是不是很简单呢。
当然上面这个例子我们使用WHERE子句加or也是可以完成这个任务的。但是对于更加复杂的过滤条件,或者从多个表中检索数据的情形,使用union可能会使处理更简单。
union规则
union的使用虽然是很简单的,但是还是有一些需要注意的地方
- union必须由两条或两条以上的SELECT语句组成,语句之间用union关键词分隔。
- union中每个查询必须包含相同的列,表达式或聚集函数(不过每个列不需要以相同的次序出现)
- 列数据的类型必须兼容:类型不必完全相同,但是必须是DBMS可以隐含转换的类型。
包含或取消重复的行
union是有一个默认行为的,就是虽然 是两个SELECT语句但是对于重复的行,它是会自动去除掉的。
既然是默认行为就能改变,我们使用union all 关键词就可以返回所有匹配行。
对组合查询结果排序
union只需要在最后的一条select语句上写order by。就可以对整个结果集进行排序。