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 语句 去重复
SELECT DISTINCT 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 ,用具体的字段列表代替“*”,不要返回用不到的任何字段。

最新文章

  1. GD库常用函数
  2. Android 社交类APP 豆瓣同城Lite(安全,无广告)
  3. Web系统开发构架再思考-前后端的完全分离
  4. Atitit 热更新资源管理器&#160;自动更新管理器&#160;功能设计
  5. Java报表FineReport在医院院长查询分析系统中有什么用
  6. Eclipse常见配置及常用插件
  7. 开坑,Unix环境高级编程,转行之路又得缓缓了
  8. C/C++中的结构体
  9. 5狐网教你从零基础做Firefox os 手机应用开发赚money
  10. 新博客 Fighting
  11. HDU 1498 50 years, 50 colors(最小点覆盖,坑称号)
  12. SWT的GridData一些参数的图示
  13. Noip2016愤怒的小鸟(状压DP)
  14. 上传图文{"errcode":40007,"errmsg":"invalid media_id"}解决方案
  15. Mave手动安装jar包
  16. 满汉全席[2-SAT]
  17. 通过User-agent进行SQL注入
  18. problem:浏览器如何区分html超文本和普通文本
  19. unity8个入门代码
  20. 并发编程之 Java 三把锁

热门文章

  1. 【雕爷学编程】Arduino动手做(16)---数字触摸传感器
  2. es6 个人笔记
  3. 【JVM从小白学成大佬】开篇
  4. 图数据库 Nebula Graph 的数据模型和系统架构设计
  5. 数据读写API——IO流
  6. java 局部变量成员变量区别
  7. 宝塔安装Lsky Pro图床教程
  8. 【RabbitMQ】如何进行消息可靠投递【下篇】
  9. Python之变量的创建过程
  10. 常用maven整合