数据库系统原理之SQL(四)
数据库系统原理之SQL(四)
1. 数据更新
插入数据
INSERT…VALUES语句
#插入多条数据
insert [into] table_name (column_name,...) values ({expr | DEFAULT},...),{....}
expr:可以是常量、变量、表达式、也可以是null
DEFAULT:该列的默认值
INSERT…SET语句
#插入一条数据
insert [into] table_name set column_name="张三",column_age=12
INSERT…SELECT语句
#插入子查询出的数据,子查询的字段数量数据类型要和插入表的字段一致
insert [into] table_name [(column_name,...)] select
删除数据
DELETE FROM table_name [WHERE where_condition] [ORDER BY …] [LIMIT row_count]
修改数据
#修改数据,字段=值,条件,
UPDATE table_name SET column_name={expr1|DEFAULT} [,col_name2={expr2|DEFAULT}]
[WHERE where_condition] [ORDER BY …] [LIMIT row_count]
查询数据
SELECT 语句
SELECT [ ALL | DISTINCT | DISTINCTROW ]
select_expr[,expr...] -- 需要查询的字段
FROM table_name -- 查询的表,数据来源
[where where_condition] -- 查询条件
[GROUP BY {column_name | expr | position } -- 对查询的数据分组,
[ASC|DeSC],...[WITH ROLLUP]]
[HAVING where_condition] -- 指定组的选择条件
[ORDER BY {column_name | expr | position } -- 对查询的结果进行排序
[ASC | DESC ]...]
[LIMIT {[offset row_count | row_count OFFSET offset }] -- 限制行数
别名
用select查询的时候可以为查询的字段设置别名,如:
SELECT class_name as name from class
查询班级名称并为字段class_name设置别名name
可以为表设置别名,如:
SELECT * FROM t_class as class where class.name="张三"
查询班级里面名字是张三的人,from的时候设置t_class的别名是class ,后面就可以直接使用别名
替换查询结果集中的数据
查询班级中同学的信息,并且把0代表女,1代表男,直接输出中文
SELECT id,name,age,
case
where sex=0 then "女" -- 如果sex是1,则输出女
where sex=1 then "男" -- 如果sex是0,则输出男
else "未确定" --否正输出未确定
end [as] "性别" -- 设置别名为性别
from class
交叉连接,又称笛卡尔积
select * from table_1 [CROSS JOIN] table_2
内连接,inner join ....on
-- 需要inner join连接用on连接两张表的外键,以形成连接关系
select * from table_1 inner join table_2 on table_1.A=table_2.A
外连接——左外连接(以左边表为基表)left join
select * from table_1 left join table_2 on table_1.A=table_2.A
外连接——右外连接(以右边表为基表)right join
select * from table_1 right join table_2 on table_1.A=table_2.A
where子句条件查询
between,把查询范围确定在某个范围内
-- 查询年龄在18到20之间的学生
select * from students where age between 18 and 20
in,列出所有指定条件的值
-- 查询年龄是18,19,20的学生
select * from students where age in (18,19,20);
-- 查询任意所选课程成绩高于80分的学生的学号和姓名信息
SELECT studentNo,studentName
FROM tb_student
WHERE studentNo IN(SELECT studentNo FROM tb_score WHERE score›80);
Group By 子句
select * from students group by class
HAVING子句(过滤分组)查询班级人数大于60的学生
select * from students group by class having count(*) >= 60
order by子句,排序。ASC升序,DESC降序
SELECT * FROM students ORDER BY age DESC,score DESC;
limit 子句,从第6个同学查询出10个同学
select * from students limit 5,10
数据库系统原理之SQL(四)的更多相关文章
- 数据库系统原理之SQL(三)
数据库系统原理之SQL(三) 1. SQL的组成 1. 数据查询 2. 数据定义 3. 数据操作 4. 数据控制 2. 数据定义语言 CREATE创建数据库或数据库对象 创建数据库 ~~~ CREAT ...
- 数据库系统原理(第四章:SQL与关系数据库基本操作 )
一.SQL概述 sql是结构化查询语言(Structured Query Language,SQL)是专门用来与数 据库通信的语言,它可以帮助用户操作关系数据库. SQL的特点: SQL不是某个特定数 ...
- Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx
Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx 1.1. 数据库的类型,网状,层次,树形数据库,kv数据库.oodb2 1.2. Er模型2 1.3. Sql2 ...
- php面试专题---Mysql索引原理及SQL优化
php面试专题---Mysql索引原理及SQL优化 一.总结 一句话总结: 注意:只写精品 1.为表设置索引要付出代价 是什么? 存储空间:一是增加了数据库的存储空间 修改插入变动索引时间:二是在插入 ...
- 数据库系统原理——ER模型与关系模型
原文链接: http://blog.csdn.net/haovip123/article/details/21614887 犹记得第一次看<数据库系统原理>时看天书的感觉,云里雾里:现在已 ...
- JAVA-Unit01: 数据库原理 、 SQL(DDL、DML)
Unit01: 数据库原理 . SQL(DDL.DML) SQL语句是不区分大小写的,但是行业里习惯将关键字与分关键字用大小写岔开以提高可读性. SELECT SYSDATE FROM dual DD ...
- WebSocket原理与实践(四)--生成数据帧
WebSocket原理与实践(四)--生成数据帧 从服务器发往客户端的数据也是同样的数据帧,但是从服务器发送到客户端的数据帧不需要掩码的.我们自己需要去生成数据帧,解析数据帧的时候我们需要分片. 消息 ...
- Vue双向绑定的实现原理系列(四):补充指令解析器compile
补充指令解析器compile github源码 补充下HTML节点类型的知识: 元素节点 Node.ELEMENT_NODE(1) 属性节点 Node.ATTRIBUTE_NODE(2) 文本节点 N ...
- RocketMQ架构原理解析(四):消息生产端(Producer)
RocketMQ架构原理解析(一):整体架构 RocketMQ架构原理解析(二):消息存储(CommitLog) RocketMQ架构原理解析(三):消息索引(ConsumeQueue & I ...
随机推荐
- 微信小程序中的自定义组件(components)
其实小程序开发很像vue和react的结合,数据绑定和setData 重新渲染页面的数据,最近发现连写组件都是很像,也是醉了,自我认为哈, 因为小程序可以将页面内的功能模块抽象成自定义组件,以便在 ...
- oracle基本语句(第四章、数据库安全管理)
1.用SYS用户以SYSDBA身份登录SQL Plus,使用DBA_USERS视图查看用户信息: SELECT USERNAME, ACCOUNT_STATUS, CREATED FROM DBA_U ...
- 【ZJOJ1321】灯
题目 贝希和她的闺密们在她们的牛棚中玩游戏.但是天不从人愿,突然,牛棚的电源跳闸了,所有的灯都被关闭了.贝希是一个很胆小的女生,在伸手不见拇指的无尽的黑暗中,她感到惊恐,痛苦与绝望.她希望您能够帮帮她 ...
- 【NOIP2016提高A组五校联考2】running
题目 小胡同学是个热爱运动的好孩子. 每天晚上,小胡都会去操场上跑步,学校的操场可以看成一个由n个格子排成的一个环形,格子按照顺时针顺序从0 到n- 1 标号. 小胡观察到有m 个同学在跑步,最开始每 ...
- 【Islands and Bridges】题解
题目 题目描述 给定一些岛屿和一些连接岛屿的桥梁,大家都知道汉密尔顿路是访问每个岛屿一次的路线,在我们这个地图中,每个岛屿有个正整数的权值,表示这个岛屿的观赏价值.假设一共有N个岛屿,用Vi表示岛屿C ...
- Chrome开发者工具面板 F12 调试大全 记录
面板上包含了Elements面板.Console面板.Sources面板.Network面板.Timeline面板.Profiles面板.Application面板.Security面板.Audits ...
- You Only Look Once Unified, Real-Time Object Detection(你只需要看一次统一的,实时的目标检测)
我们提出了一种新的目标检测方法YOLO.先前的目标检测工作重新利用分类器来执行检测.相反,我们将目标检测作为一个回归问题来处理空间分离的边界框和相关的类概率.单个神经网络在一次评估中直接从完整图像预测 ...
- Sql Server2008中自定义函数调用存储过程解决方案
1.开启sql server 2008远程连接 打开sql server配置管理器 配置SSCM,选中左侧的“SQL Server服务”,确保右侧的“SQL Server”以及“SQL Server ...
- C# walls
在学习C#的阶段中,我们一点一点的往前爬, 此代码需要添加selenium ,和 获取 引用. using Ivony.Html.Parser; using Ivony.Html; using Ope ...
- springboot切换配置
1.默认只有一个application.properties文件 1)删除properties文件,换成yml方式.新增dev,prod两个文件 2)配置application.yml文件:actio ...