本文整理自网络,侵删。
目录
- 1、简介
- 2、select
- 2.1 查询单个列
- 2.2 查询多个列
- 2.3 查询所有列
- 3、distinct
- 4、limit
1、简介
这篇博客将会非常基础,如果有MySQL
经验的可以跳过,写这篇博客的原因是给初学者看的。下面将会讲解如何使用select查看指定表的单个列、多个列以及全部列。
首先准备一张表,表结构如下所示:
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for user -- ---------------------------- DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键', `name` varchar(255) NOT NULL COMMENT '用户名', `age` int(11) NOT NULL COMMENT '年龄', `sex` smallint(6) NOT NULL COMMENT '性别', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
表数据如下所示:
INSERT INTO `user` VALUES (1, '李子捌', 18, 1); INSERT INTO `user` VALUES (2, '张三', 22, 1); INSERT INTO `user` VALUES (3, '李四', 38, 1); INSERT INTO `user` VALUES (4, '王五', 25, 1); INSERT INTO `user` VALUES (5, '六麻子', 13, 0); INSERT INTO `user` VALUES (6, '田七', 37, 1); SET FOREIGN_KEY_CHECKS = 1;
注意在MySQL4.1
之后,数据库关键字是完全不区分大小写;数据库名、表名、列名默认不区分大小写,但是可以修改(不建议修改)。
2、select
2.1 查询单个列
首先使用use
指定需要操作的数据库。
mysql> use liziba; Database changed
接着使用select
从user
表中查询name
列,select
紧跟着列名称,from
后面紧跟着表名称。
select column_name from table_name; mysql> select name from user; +--------+ | name | +--------+ | 李子捌 | | 张三 | | 李四 | | 王五 | | 六麻子 | | 田七 | +--------+ 6 rows in set (0.00 sec)
2.2 查询多个列
查询多个列和单个列的区别在于,select后面紧跟多个列名,用英文逗号分割即可。
select column_name1,column_name2,column_name3 from table_name;
mysql> select name,age from user; +--------+-----+ | name | age | +--------+-----+ | 李子捌 | 18 | | 张三 | 22 | | 李四 | 38 | | 王五 | 25 | | 六麻子 | 13 | | 田七 | 37 | +--------+-----+ 6 rows in set (0.00 sec)
2.3 查询所有列
查询所有列有两种方式,第一种是上面两种推导出的方式,列出所有的列名。
mysql> select id,name,age,sex from user; +----+--------+-----+-----+ | id | name | age | sex | +----+--------+-----+-----+ | 1 | 李子捌 | 18 | 1 | | 2 | 张三 | 22 | 1 | | 3 | 李四 | 38 | 1 | | 4 | 王五 | 25 | 1 | | 5 | 六麻子 | 13 | 0 | | 6 | 田七 | 37 | 1 | +----+--------+-----+-----+ 6 rows in set (0.00 sec)
第二种,也是部分程序员使用的最多的一句SQL
,使用 *** 通配符**代替表的所有列。
select * from table_name;
mysql> select * from user; +----+--------+-----+-----+ | id | name | age | sex | +----+--------+-----+-----+ | 1 | 李子捌 | 18 | 1 | | 2 | 张三 | 22 | 1 | | 3 | 李四 | 38 | 1 | | 4 | 王五 | 25 | 1 | | 5 | 六麻子 | 13 | 0 | | 6 | 田七 | 37 | 1 | +----+--------+-----+-----+ 6 rows in set (0.00 sec)
提示:是程序员使用的大忌, 如果我们不需要获取表的所有列且表的列名是移植的,就不应该使用查询全部数据,而是应该指定数据库列查询,这样可以提升查询的性能。
3、distinct
如果需要查询列值不重复的数据,可以使用distinct
关键字去重。
相关阅读 >>
更多相关阅读请进入《mysql》频道 >>
数据库系统概念 第6版
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » MySQL之select、distinct、limit的使用
标签:mysql
相关推荐
评论
管理员已关闭评论功能...