数据库学习 day2 检索数据
上一节我们介绍了什么是数据库,以及一些基本的数据库术语
这一课介绍使用SELECT语句从表中检索一个或多个数据列。
关键字(Keyword)
作为SQL组成部分的保留字。关键字不能用作表和列的名字(类比C语言中的int、print等)。
1 SELECT语句
它是在SQL语句中最常使用的语句,作用是从一个或多个表中检索信息。
使用SELECT检索表数据,需要知道两个信息,我们要从哪里进行搜索,搜索哪些内容。
1.2 检索单列
SELECT column_name -- 列名
FROM table_name; -- 表名
解释:上述语句用 SELECT 语句从 table_name 表中检索一个名为 column_name 的列。
列名跟在SELECT后 表名跟在FORM后,这与我们的自然语言相同
注意:
- 没有明确排序查询的结果,则返回的数据没有特定的顺序,这个规定我们将在下一节进行介绍。
- 多条SQL语句必须加分号。
- SQL不区分大小写。
- 使用空格和回车的作用相同,所以SQL语句和写在一行或多行,但为了代码清晰易查建议分为多行。
1.3 检索多列
想从一个表中检索多个列,仍然需要使用 SELECT 语句。唯一的不同就是SELECT后面检索的内容需用逗号隔开。
SELECT column_name,column_name1,column_name2 -- 列名
FROM table_name; -- 表名
在本例中我们指定了3个列名,彼此用逗号相隔。
注意:
从SQL中检索出的数据都是原始的数据,无格式数据。规定其格式一般在具体应用该数据的应用程序中进行。
1.4 检索所有列
SELECT语句还可以检索出所有列而不必逐个列出它们的名字。在实际列名的位置使用星号(*)通配符可以做到这一点。
SELECT * -- 使用通配符
FROM table_name; -- 表名
给定通配符(*),则返回所有的列。使用通配符的可以检索出名字未知的列。
1.5 检索出不同的值
当检索结果中出现多个重复值时,我们希望每个只出现一次怎么办?比如搜索一个年级学生的班级信息就会出现大量的重复,我们只需要不同的班级值
办法就是使用DISTINCT关键字,顾名思义,它指示数据库返回不同的值。
SELECT DISTINCT column_name -- 检索不同的值
FROM table_name -- 表名
如果使用DISTINCT关键字,它必须放在列名前。
若DISTINCT关键字后有多列,不仅仅是作用于一列,而是所有列。
1.6 限制结果
SELECT返回指定列中的所有匹配列,而你想返回1列或指定数量的列怎么办呢?这在数据库操作中是可行的,但各个SQL软件实现方法不同。
这里只说明MySQL的实现方法,其他软件的可以根据需要自行查讯。
MySQL中需要使用LIMIT子句,像这样
SELECT column_name -- 列名
FROM table_name -- 表名
LIMIT 5;
LIMIT 5指示 MySQL 等 DBMS 返回不超过5行的数据。
为了得到后5行的数据,我们还需指定从哪里开始检索
SELECT column_name -- 列名
FROM table_name -- 表名
LIMIT 5 OFFSET 5;
注意:
第一个被检索的行是第0行,而不是第一行。所以,LIMIT 5 OFFSET 5 会检索第6行而不是第5行。
2 使用注释
我上面的语句均使用了注释,使用“--”后面空一格跟需要注释的内容
当然还有多行注释
/*this is a note
SELECT FROM
*/
SELECT column_name -- 列名
FROM table_name -- 表名
LIMIT 5 OFFSET 5;
这在我们调试代码时很有用,可以让你无需将错误的代码删除,只需注释掉它们就行了
数据库学习 day2 检索数据的更多相关文章
- 数据库学习任务四:数据读取器对象SqlDataReader、数据适配器对象SqlDataAdapter、数据集对象DataSet
数据库应用程序的开发流程一般主要分为以下几个步骤: 创建数据库 使用Connection对象连接数据库 使用Command对象对数据源执行SQL命令并返回数据 使用DataReader和DataSet ...
- 黑马MySQL数据库学习day02 表数据CRUD 约束CRUD
/* 基础查询练习: 1.字段列表查询 当查询全部字段时,一种简便方式,使用*代替全部字段(企业中不推荐使用) 2.去除重复行 DISTINCT,注意修饰的是行,也就是整个字段列表,而不是单个字段. ...
- 数据库学习其一 oracle11g数据泵导入导出
一.检查环境一致性 需检查数据库客户端与服务端字符编码,以避免后续各种各样的问题 查询服务端编码 注意最好用sqlplus查询,用plsql有时候会出现查询不一致问题,如下图同一个语句在plsql和s ...
- 吴裕雄--天生自然ORACLE数据库学习笔记:数据表对象
create table students( stuno ) not null, --学号 stuname ), --姓名 sex ), --性别 age int, --年龄 departno ) n ...
- 吴裕雄--天生自然ORACLE数据库学习笔记:数据导出与导入
create directory dump_dir as 'd:\dump'; grant read,write on directory dump_dir to scott; --在cmd下 exp ...
- ORACLE数据库学习之SQL性能优化详解
Oracle sql 性能优化调整 ...
- 学习笔记:oracle学习三:SQL语言基础之检索数据:简单查询、筛选查询
目录 1. 检索数据 1.1 简单查询 1.1.1 检索所有列 1.1.2 检索指定的列 1.1.3 查询日期列 1.1.4 带有表达式的select语句 1.1.5 为列指定别名 1.1.6 显示不 ...
- PHP 数据库驱动、连接数据不同方式学习笔记
相关学习资料 http://www.php.net/manual/zh/refs.database.php http://www.php.net/manual/zh/internals2.pdo.ph ...
- python学习笔记--Django入门三 Django 与数据库的交互:数据建模
把数据存取逻辑.业务逻辑和表现逻辑组合在一起的概念有时被称为软件架构的 Model-View-Controller (MVC)模式.在这个模式中, Model 代表数据存取层,View 代表的是系统中 ...
随机推荐
- django 从零开始 4 404页面和500页面设置
在视图函数中定义两个 函数 分别对应404 个500页面 (自定义html内容吧,这里只是展示) 在template页面指向自己定义的404.html和500.html页面 在项目的urls中设置 h ...
- 回想笔记 瞎比比 域名注册 解析绑定ip 下载证书 设置证书 重定向http到https请求
2019.7.27 回想笔记 拥有腾讯云服务器一台 阿里云注册5元域名,进行备案 完成之后 使用解析 绑定服务器ip地址 ,使用域名可以访问到web服务器而不是通过直接暴露ip地址进行访问 证书购买 ...
- scrapy中间件中使用selenium切换ip
scrapy抓取一些需要js加载页面时一般要么是通过接口直接获取数据,要么是js加载,但是我通过selenium也可以获取动态页面 但是有个问题,容易给反爬,因为在scrapy中间件mid中使用sel ...
- 建议8:恰当选用if和switch
相对来说下面几种情况更适合switch结构 枚举表达式的值.这种枚举是可以期望的,平行逻辑关系的 表达式的值具有离散性,不具有线性的非连续的区间值 表达式的值是固定的,不是动态变化的 表达式的值是有限 ...
- Layui select下拉框改变之 change 监听事件(转)
在layui中使用 jquery 触发select 的 change事件无效 使用layui.use监听select事件 <select lay-filter="demo" ...
- 转载:Nginx 相关介绍
转载自:https://www.cnblogs.com/wcwnina/p/8728391.html Nginx 相关介绍(Nginx是什么?能干嘛?) Nginx的产生 没有听过Nginx?那么 ...
- [Linux][C][gcc] Linux GCC 编译链接 报错ex: ./libxxx.so: undefined reference to `shm_open'
本人原创文章,文章是在此代码github/note的基础上进行补充,转载请注明出处:https://github.com/dramalife/note. 以librt丶用户自定义动态库libxxx 和 ...
- shell脚本基础-四种启动方式
1.当前路径启动 ./test.sh 2.绝对路径启动 pwd /data/beijing 'pwd'/test.sh 3.指定解释器执行 sh test.sh bash test.sh 4.shel ...
- Springboot使用Undertow
Springboot使用Undertow Undertow 是红帽公司开发的一款基于 NIO 的高性能 Web 嵌入式服务器 Undertow的特点: 轻量级:它是一个 Web 服务器,但不像传统的 ...
- 基于 HTML5 WebGL 的 智慧楼宇能源监控系统
前言 21世纪,在能源危机和全球气候变暖的压力下,太阳能等可再生能源越来越受到关注,其中光伏建筑一体化逐渐成为绿色发展方式和生活方式,加强节能降耗,支持低碳产业和新能源.可再生能源发展,也已经成为国家 ...