一:mysql 数据的插入 

  语法

  以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法:

  INSERT INTO table_name ( field1, field2,...fieldN )
VALUES
( value1, value2,...valueN );

  如果数据是字符型,必须使用单引号或者双引号,如:"value"。

MariaDB [test2]> desc student;
+--------+----------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+----------+------+-----+---------+----------------+
| stu_id | int(11) | NO | PRI | NULL | auto_increment |
| name | char(10) | NO | | NULL | |
| age | int(11) | NO | | NULL | |
| sex | char(2) | NO | | F | |
+--------+----------+------+-----+---------+----------------+
4 rows in set (0.00 sec) MariaDB [test2]> insert into student (name,age,sex) values('shisanjun',23,'F');
Query OK, 1 row affected (0.00 sec)

二:MySQL 查询数据 

  语法

  以下为在MySQL数据库中查询数据通用的 SELECT 语法:

  SELECT column_name,column_name
  FROM table_name
  [WHERE Clause]
  [OFFSET M ][LIMIT N]
  • 查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件。
  • SELECT 命令可以读取一条或者多条记录。
  • 你可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
  • 你可以使用 WHERE 语句来包含任何条件。
  • 你可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0。
  • 你可以使用 LIMIT 属性来设定返回的记录数。
MariaDB [test2]> select * from student;
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 1 | shisanjun | 23 | F |
| 2 | shisanjun2 | 23 | F |
| 3 | shisanjun3 | 24 | F |
+--------+------------+-----+-----+
3 rows in set (0.00 sec) MariaDB [test2]> select * from student limit 2 offset 1; offset必须要和limit一起使用,而且limit在前端
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 2 | shisanjun2 | 23 | F |
| 3 | shisanjun3 | 24 | F |
+--------+------------+-----+-----+
2 rows in set (0.00 sec) MariaDB [test2]> select * from student offset 1; 报错了
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual
that corresponds to your MariaDB server version for the right syntax to use near '' at line 1
MariaDB [test2]> select * from student limit 2 ,1; 表示从第2条后面开始查询1条
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 3 | shisanjun3 | 24 | F |
+--------+------------+-----+-----+
1 row in set (0.00 sec) MariaDB [test2]>

三:mysql where 子句

  

  语法

  以下是 SQL SELECT 语句使用 WHERE 子句从数据表中读取数据的通用语法:

  SELECT field1, field2,...fieldN FROM table_name1, table_name2...
  [WHERE condition1 [AND [OR]] condition2.....
  • 查询语句中你可以使用一个或者多个表,表之间使用逗号, 分割,并使用WHERE语句来设定查询条件。
  • 你可以在 WHERE 子句中指定任何条件。
  • 你可以使用 AND 或者 OR 指定一个或多个条件。
  • WHERE 子句也可以运用于 SQL 的 DELETE 或者 UPDATE 命令。
  • WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。

以下为操作符列表,可用于 WHERE 子句中

下表中实例假定 A 为 10, B 为 20

操作符 描述 实例
= 等号,检测两个值是否相等,如果相等返回true (A = B) 返回false。
<>, != 不等于,检测两个值是否相等,如果不相等返回true (A != B) 返回 true。
> 大于号,检测左边的值是否大于右边的值, 如果左边的值大于右边的值返回true (A > B) 返回false。
< 小于号,检测左边的值是否小于右边的值, 如果左边的值小于右边的值返回true (A < B) 返回 true。
>= 大于等于号,检测左边的值是否大于或等于右边的值, 如果左边的值大于或等于右边的值返回true (A >= B) 返回false。
<= 小于等于号,检测左边的值是否小于于或等于右边的值, 如果左边的值小于或等于右边的值返回true (A <= B) 返回 true。

如果我们想再 MySQL 数据表中读取指定的数据,WHERE 子句是非常有用的。

使用主键来作为 WHERE 子句的条件查询是非常快速的。

如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。

MariaDB [test2]> select * from student where sex='F';
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 1 | shisanjun | 23 | F |
| 2 | shisanjun2 | 23 | F |
| 3 | shisanjun3 | 24 | F |
+--------+------------+-----+-----+

四:MySQL UPDATE 查询

如果我们需要修改或更新 MySQL 中的数据,我们可以使用 SQL UPDATE 命令来操作。.

  语法

  以下是 UPDATE 命令修改 MySQL 数据表数据的通用 SQL 语法:

  UPDATE table_name SET field1=new-value1, field2=new-value2
  [WHERE Clause]
  • 你可以同时更新一个或多个字段。
  • 你可以在 WHERE 子句中指定任何条件。
  • 你可以在一个单独表中同时更新数据。

  当你需要更新数据表中指定行的数据时 WHERE 子句是非常有用的。

MariaDB [test2]> update student set sex='M';
Query OK, 3 rows affected (0.00 sec)
Rows matched: 3 Changed: 3 Warnings: 0 MariaDB [test2]> select * from student;
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 1 | shisanjun | 23 | M |
| 2 | shisanjun2 | 23 | M |
| 3 | shisanjun3 | 24 | M |
+--------+------------+-----+-----+
3 rows in set (0.00 sec)

五:MySQL DELETE 语句

你可以使用 SQL 的 DELETE FROM 命令来删除 MySQL 数据表中的记录。

  语法

  以下是 SQL DELETE 语句从 MySQL 数据表中删除数据的通用语法:

  DELETE FROM table_name [WHERE Clause]
  • 如果没有指定 WHERE 子句,MySQL 表中的所有记录将被删除。
  • 你可以在 WHERE 子句中指定任何条件
  • 您可以在单个表中一次性删除记录。

  当你想删除数据表中指定的记录时 WHERE 子句是非常有用的。

MariaDB [test2]> delete from student where name='shisanjun3';
Query OK, 1 row affected (0.00 sec) 

六:MySQL LIKE 子句

语法

以下是 SQL SELECT 语句使用 LIKE 子句从数据表中读取数据的通用语法:

SELECT field1, field2,...fieldN
FROM table_name
WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
  • 你可以在 WHERE 子句中指定任何条件。
  • 你可以在 WHERE 子句中使用LIKE子句。
  • 你可以使用LIKE子句代替等号 =。
  • LIKE 通常与 % 一同使用,类似于一个元字符的搜索。
  • 你可以使用 AND 或者 OR 指定一个或多个条件。
  • 你可以在 DELETE 或 UPDATE 命令中使用 WHERE...LIKE 子句来指定条件。
MariaDB [test2]> select * from student where name like 'shisanjun%';
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 1 | shisanjun | 23 | M |
| 2 | shisanjun2 | 23 | M |
+--------+------------+-----+-----+
2 rows in set (0.00 sec)

MySQL居然不区分大小写,可以使用binary将字符串先转换为二进制字符串

MariaDB [test2]> select name,count(name) from student group by name;
+------------+-------------+
| name | count(name) |
+------------+-------------+
| shisanjun | 4 |
| shisanjun2 | 1 |
| shisanjun3 | 2 |
+------------+-------------+
3 rows in set (0.00 sec)
可以使用binary将字符串先转换为二进制字符串,在进行比较
MariaDB [test2]> select name,count(name) from student group by binary name;
+------------+-------------+
| name | count(name) |
+------------+-------------+
| Shisanjun | 1 |
| shisanjun | 3 |
| shisanjun2 | 1 |
| shisanjun3 | 2 |
+------------+-------------+
4 rows in set (0.00 sec)

参考资料:http://www.linuxidc.com/Linux/2014-06/102870.htm

七:MySQL 排序

语法

以下是 SQL SELECT 语句使用 ORDER BY 子句将查询数据排序后再返回数据:

SELECT field1, field2,...fieldN from table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
  • 你可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
  • 你可以设定多个字段来排序。
  • 你可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。
  • 你可以添加 WHERE...LIKE 子句来设置条件。
MariaDB [test2]> select * from student order by name;
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 1 | shisanjun | 23 | M |
| 6 | shisanjun | 25 | F |
| 7 | shisanjun | 26 | F |
| 2 | shisanjun2 | 23 | M |
| 4 | shisanjun3 | 24 | F |
| 5 | shisanjun3 | 25 | F |
+--------+------------+-----+-----+
6 rows in set (0.00 sec) MariaDB [test2]> select * from student order by name desc;
+--------+------------+-----+-----+
| stu_id | name | age | sex |
+--------+------------+-----+-----+
| 4 | shisanjun3 | 24 | F |
| 5 | shisanjun3 | 25 | F |
| 2 | shisanjun2 | 23 | M |
| 1 | shisanjun | 23 | M |
| 6 | shisanjun | 25 | F |
| 7 | shisanjun | 26 | F |
+--------+------------+-----+-----+
6 rows in set (0.00 sec)

八:MySQL GROUP BY 语句

  GROUP BY 语句根据一个或多个列对结果集进行分组。

  在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。

  GROUP BY 语法

  SELECT column_name, function(column_name)
  FROM table_name
  WHERE column_name operator value
  GROUP BY column_name;

  使用 WITH ROLLUP

  WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM,AVG,COUNT…)。

  例如我们将以上的数据表按名字进行分组,再统计每个人登录的次数:

 可以使用 coalesce 来设置一个可以取代 NUll 的名称
MariaDB [test2]> select name,count(name) from student group by binary name with rollup;
+------------+-------------+
| name | count(name) |
+------------+-------------+
| Shisanjun | 1 |
| shisanjun | 3 |
| shisanjun2 | 1 |
| shisanjun3 | 2 |
| shisanjun3 | 7 |
+------------+-------------+
5 rows in set (0.01 sec) MariaDB [test2]> select name,count(name) from student group by name with rollup;
+------------+-------------+
| name | count(name) |
+------------+-------------+
| shisanjun | 4 |
| shisanjun2 | 1 |
| shisanjun3 | 2 |
| NULL | 7 |
+------------+-------------+
4 rows in set (0.00 sec) MariaDB [test2]> select coalesce(name,total),count(name) from student group by name with rollup;
ERROR 1054 (42S22): Unknown column 'total' in 'field list'
MariaDB [test2]> select coalesce(name,'total'),count(name) from student group by name with rollup;
+------------------------+-------------+
| coalesce(name,'total') | count(name) |
+------------------------+-------------+
| shisanjun | 4 |
| shisanjun2 | 1 |
| shisanjun3 | 2 |
| total | 7 |
+------------------------+-------------+
4 rows in set (0.00 sec)

九:MySQL NULL 值处理

  我们已经知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作。

  为了处理这种情况,MySQL提供了三大运算符:

  • IS NULL: 当列的值是 NULL,此运算符返回 true。
  • IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
  • <=>: 比较操作符(不同于=运算符),当比较的的两个值为 NULL 时返回 true。

  关于 NULL 的条件比较运算是比较特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。

  在 MySQL 中,NULL 值与任何其它值的比较(即使是 NULL)永远返回 false,即 NULL = NULL 返回false 。

  MySQL 中处理 NULL 使用 IS NULL 和 IS NOT NULL 运算符。

最新文章

  1. Git安装
  2. 监听SD卡状态
  3. python yield的初识
  4. Python第十二章正则表达式
  5. Android 5.x特性概览五
  6. AngularJS学习笔记1
  7. Git使用简介
  8. IE10用video标签播放本地mp4文件失败的解决办法
  9. SpringMVC入门1
  10. angular启动过程分析
  11. leetcode算法刷题(四)——动态规划(二)
  12. [Script]EBS里查看模块的版本、文件的版本信息【Z】
  13. MT【277】华中科技大学理科实验班选拔之三次方程
  14. Docker 国内仓库和镜像
  15. adb获得安卓系统版本及截屏
  16. [AWS] Serverless
  17. linux 压缩工具
  18. C#根据进程名称获取进程的句柄?
  19. maven pom属性 详解
  20. 20145315 《Java程序设计》第一周学习总结

热门文章

  1. 【转】关于在linux下清屏的几种技巧
  2. Vuejs+axios+SpringMVC 1
  3. RF - selenium - 常用关键字
  4. C++并发类成员函数调用(练习1)
  5. ElasticStack系列之十 &amp; 生产中的问题与解决方案
  6. bootstrap-switch与angularjs结合使用
  7. [LeetCode] 398. Random Pick Index ☆☆☆
  8. bzoj千题计划162:bzoj2006: [NOI2010]超级钢琴
  9. jmeter乱码问题
  10. android获取APP 包名和activity