40 (OC)* 数据库常见sql语句
1:增加
INSERT INTO t_student (name, age) VALUES ('liwx', 18);
2:删除
DELETE FROM t_student WHERE name = 'liwx';
3:修改
UPDATE t_student SET age = 19 WHERE name = 'liwx';
4:查找
SELECT name, age FROM t_student where name = 'liwx';
5:统计查询
SELECT count(age) FROM t_student;
6:排序查询
SELECT * FROM t_student ORDER BY age ASC;
SELECT * FROM t_student ORDER BY age DESC;
SELECT * FROM t_student ORDER BY age ASC, score DESC;
7:limit分页查询SELECT * FROM t_student LIMIT 4, 8;
: 跳过最前面4条语句,然后取8条记录.
8:SELECT DISTINCT 语句 去重复
SELECTDISTINCT
Company FROM Orders
9:AND和OR
SELECT * FROM Persons WHERE(
FirstName='Thomas'OR
FirstName='William')
AND
LastName='Carter'
10:模糊搜索
SELECT * FROM Persons WHERE City LIKE '%g'
11:在
数据库操作操作(增删改查)
插入数据(insert)
- 1.插入数据格式
注意
: 数据库中的字符串内容应该用单引号 ’ 括住;
格式:
insert into 表名 (字段1, 字段2, …) values (字段1的值, 字段2的值, …) ;
- 2.插入数据示例
插入数据示例:
INSERT INTO t_student (name, age) VALUES ('liwx', 18);
更新数据(update)
- 1.更新数据格式
格式:
update 表名 set 字段1 = 字段1的值, 字段2 = 字段2的值 where 条件;
- 2.更新数据示例
注意
: WHERE 条件是=
号,不是==号.
更新数据示例:
UPDATE t_student SET age = 19 WHERE name = 'liwx';
删除数据(delete)
- 1.删除数据格式
格式:
delete from 表名 where 条件;
- 2.更新数据示例
更新数据示例:
DELETE FROM t_student WHERE name = 'liwx';
DQL数据库查询语句(查询)
- 1.查询数据格式
格式1:
select * from 表名;
,*
:通配符,表示所有字段.
格式2:select 字段1, 字段2, … from 表名;
格式3:select 字段1, 字段2, … from 表名 where 条件;
- 2.查询数据示例
更新数据示例1:
SELECT * FROM t_student;
更新数据示例2:SELECT name, age FROM t_student;
更新数据示例3:SELECT name, age FROM t_student where name = 'liwx';
4.查询相关语句
统计查询
- 1.
count(X)
计算记录个数
计算所有记录个数:
SELECT count(*) FROM t_student;
计算age有值的记录个数(Null不计算在内):
SELECT count(age) FROM t_student;
- 2.
avg(X)
计算某个字段的平均值 - 3.
sum(X)
计算某个字段的总和 - 4.
max(X)
计算某个字段的最大值 - 5.
min(X)
计算某个字段的最小值
排序查询
- 1.升序ASC
格式:
SELECT 字段1(或*) FROM 表名 ORDER BY 要排序的字段名 ASC;
示例:
SELECT * FROM t_student ORDER BY age ASC;
- 2.降序
格式:
SELECT 字段1(或*) FROM 表名 ORDER BY 要排序的字段名 DESC;
示例:
SELECT * FROM t_student ORDER BY age DESC;
- 3.多个字段排序
格式:
SELECT * FROM 表名 ORDER BY 字段名1 排序类型, 字段名2 排序类型;
示例:
SELECT * FROM t_student ORDER BY age ASC, score DESC;
limit分页查询
- 1.limit分页查询
格式:
select * from 表名 limit 数值1, 数值2 ;
示例:
SELECT * FROM t_student LIMIT 4, 8;
: 跳过最前面4条语句,然后取8条记录.
- 2.查询第n页的数据
- 假设一页显示5条数据.
示例:
SELECT * FROM t_student LIMIT 5*(n-1), 5;
- 3.特殊案例
示例:
select * from t_student limit 7;
相当于:select * from t_student limit 0, 7;
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。
2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:
select id from t where num is null
可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:
select id from t where num=0
3.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描。
4.应尽量避免在 where 子句中使用 or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描,如:
select id from t where num=10 or num=20
可以这样查询:
select id from t where num=10
union all
select id from t where num=20
5.in 和 not in 也要慎用,否则会导致全表扫描,如:
select id from t where num in(1,2,3)
对于连续的数值,能用 between 就不要用 in 了:
select id from t where num between 1 and 3
很多时候用 exists 代替 in 是一个好的选择:
select num from a where num in(select num from b)
用下面的语句替换:
select num from a where exists(select 1 from b where num=a.num)
6.下面的模糊查询也将导致全表扫描:
select id from t where name like ‘%abc%’
select id from t where name like ‘%abc’
但是下面的这种模糊查询依然可以使用索引
select id from t where name like ‘abc%’
7.应尽量避免在 where 子句中对字段的“=”左边进行函数、算术运算或其他表达式运算,这将导致引擎放弃使用索引而进行全表扫描。
如:
select id from t where num/2=100
应改为:
select id from t where num=100*2
又如查找name以abc开头的id:
select id from t where substring(name,1,3)=’abc’
应改为:
select id from t where name like ‘abc%’
8.不要使用 select * from table ,用具体的字段列表代替“*”,不要返回用不到的任何字段。
40 (OC)* 数据库常见sql语句的更多相关文章
- SQL Server 【附】创建"商品管理数据库"、"学生选课数据库"的SQL语句
附:(创建“商品管理数据库”的SQL语句) --建立"商品管理数据库"数据库-- create database 商品管理数据库 on(name='商品管理数据库_m', file ...
- Access、SQLServer、Oracle常见SQL语句应用区别
Access.SQLServer.Oracle常见SQL语句应用区别 关劲松 PMP 如果要兼容Access.SQL Server.Oracle三个数据库版本:我们在编写SQL语句的过程中,尽量使用一 ...
- mysql(数据库,sql语句,普通查询)
第1章 数据库 1.1 数据库概述 l 什么是数据库 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作. l 什 ...
- 《大话数据库》-SQL语句执行时,底层究竟做了什么小动作?
<大话数据库>-SQL语句执行时,底层究竟做了什么小动作? 前言 大家好,我是Taoye,试图用玩世不恭过的态度对待生活的Coder. 现如今我们已然进入了大数据时代,无论是业内还是业外的 ...
- 解决死锁之路3 - 常见 SQL 语句的加锁分析 (转)
出处:https://www.aneasystone.com/archives/2017/12/solving-dead-locks-three.html 这篇博客将对一些常见的 SQL 语句进行加锁 ...
- 总结一些关于操作数据库是sql语句还是存储过程问题
总结一些关于操作数据库是sql语句还是存储过程问题 程序中,你跟数据的交互,需要向数据库拿数据.更改数据库的数据等,这些操作,本身不是程序完成的,而是程序发命令给数据库去做的,不管是通过sql语句方式 ...
- 在线数据库表(sql语句)生成java实体类工具
相信每个做java开发的读者,都接触过SQL建表语句,尤其是在项目开发初期,因为数据库是项目的基石. 在现代项目开发中,出现了许多ORM框架,通过简单的实体映射,即可实现与数据库的交互,然而我们最初设 ...
- GP数据库 常用SQL语句
GP数据库 常用SQL语句 --1,查看列名以及类型 select upper(column_name) ,data_type from information_schema.columns wher ...
- Oracle数据库 基础SQL语句练习
一.说明 第一次使用Oracle,想做一些练习,熟悉一些oracle. 表:使用的是scott用户,默认的表 具体表讲解,可以参考该文档:https://www.cnblogs.com/xjcheng ...
随机推荐
- HTTP请求包和响应包
HTTP请求包 HTTP响应包
- vue入门:用户管理demo
该demo纯前端实现 使用到vue技术点: 1.在该demo中使用到的vue指令:{{}}. v-if. v-model. @click v-for 2.在该demo中使用到的事件修饰符: .prev ...
- java两个对象属性比较
两个对象进行比较相等,有两种做法: 1,情况一:当仅仅只是判断两个对象是否相等时,只需重写equals()方法即可.这里就不用说明 2.情况二:当除了情况一之外,还需知道是那个属性不同,那么就需要采用 ...
- Docker学习总结(七)--Docker私有仓库
创建私有仓库 1) 拉取私有仓库镜像 docker pull registry 2)启动私有仓库容器 docker run -di --name-registry -p 5000:5000 regis ...
- Ribbon实现客户端负载均衡
什么是Ribbon? 客户端负载均衡组件. 前期准备: 搭建一个Eureka集群和一个注册服务 https://www.cnblogs.com/noneplus/p/11374883.html 创建服 ...
- thinkPHP中的简单文章推荐(按浏览量)功能实现
在公司中接触到了thinkPHP框架,其中要在项目中实现文章推荐功能.记录笔记如下: 一.在Controller中获取从文章列表页进入详情页传入的文章ID值. 二.在Controller中绑定数据库查 ...
- Ajax数据解析格式
Ajax数据解析格式 一.前言 在服务器端 AJAX 是一门与语言无关的技术.在业务逻辑层使用何种服务器端语言都可以. 从服务器端接收数据的时候,那些数据必须以浏览器能够理解的格式来发送.服务器端的编 ...
- Nginx总结(四)基于域名的虚拟主机配置
前面讲了如何安装配置Nginx,大家可以去这里看看nginx系列文章:https://www.cnblogs.com/zhangweizhong/category/1529997.html 今天要说的 ...
- NLP(二十三)使用LSTM进行语言建模以预测最优词
N元模型 预测要输入的连续词,比如 如果抽取两个连续的词汇,则称之为二元模型 准备工作 数据集使用 Alice in Wonderland 将初始数据提取N-grams import nltk imp ...
- 微服务时代之网关相关技术选型及部署(nacos+gateway)
1.场景描述 因要用到微服务,关于注册中心这块,与同事在技术原型上做了讨论,初步定的方案是使用:阿里巴巴的nacos+springcloud gateway,下面表格是同事整理的注册中心对比,以前用的 ...