数据库-mysql数据操作

时间:2022-08-28 08:30:44

一: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 运算符。

数据库-mysql数据操作的更多相关文章

  1. 第二百八十六节,MySQL数据库-MySQL事务操作&lpar;回滚&rpar;

    MySQL数据库-MySQL事务操作(回滚) 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 举例:有这样一张表 从表里可以看出张 ...

  2. SQL学习笔记四之MySQL数据操作

    阅读目录 一 介绍 二 插入数据INSERT 三 更新数据UPDATE 四 删除数据DELETE 五 查询数据SELECT 六 权限管理 一 介绍 MySQL数据操作: DML =========== ...

  3. python 基础 9&period;3 mysql 数据操作

    #/usr/bin/python #coding=utf-8 #@Time   :2017/11/21 0:20 #@Auther :liuzhenchuan #@File   :mysql 数据操作 ...

  4. Python数据库之数据操作

    一 介绍 MySQL数据操作: DML ======================================================== 在MySQL管理软件中,可以通过SQL语句中的 ...

  5. MySQL数据操作与查询笔记 • 【目录】

    持续更新中- 我的大学笔记>>> 章节 内容 第1章 MySQL数据操作与查询笔记 • [第1章 MySQL数据库基础] 第2章 MySQL数据操作与查询笔记 • [第2章 表结构管 ...

  6. 数据库 -- mysql记录操作

    一,概括 MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用DELETE实现 ...

  7. mysql 数据操作 目录

    mysql 记录的增删改查 mysql 数据操作 单表查询 mysql 数据操作 多表查询

  8. spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置

    spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...

  9. mysql 数据操作 单表查询 目录

    mysql 数据操作 单表查询 mysql 数据操作 单表查询 简单查询 避免重复DISTINCT mysql 数据操作 单表查询 通过四则运算查询 mysql 数据操作 单表查询 concat()函 ...

随机推荐

  1. leetcode 199 &colon;Binary Tree Right Side View

    // 我的代码 package Leetcode; /** * 199. Binary Tree Right Side View * address: https://leetcode.com/pro ...

  2. Ant 执行 YUICompressor

    Ant 执行 YUICompressor 任务压缩 JavaScript 和 CSS 文件,解决中文乱码问题,增加源文件字符编码集设定 标签: javascriptantcss任务encodingnu ...

  3. Android使用 LruCache 缓存图片

    摘要:在你应用程序的UI界面加载一张图片是一件很简单的事情,但是当你需要在界面上加载一大堆图片的时候,情况就变得复杂起来. 使用图片缓存技术 在 你应用程序的UI界面加载一张图片是一件很简单的事情,但 ...

  4. 一次线上OOM故障排查经过

    转贴:http://my.oschina.net/flashsword/blog/205266 本文是一次线上OOM故障排查的经过,内容比较基础但是真实,主要是记录一下,没有OOM排查经验的同学也可以 ...

  5. js获取本月第几周和本年第几周

    var getMonthWeek = function (a, b, c) { /* a = d = 当前日期 b = 6 - w = 当前周的还有几天过完(不算今天) a + b 的和在除以7 就是 ...

  6. Python urllib和urllib2模块学习&lpar;一)

    (参考资料:现代魔法学院 http://www.nowamagic.net/academy/detail/1302803) Python标准库中有许多实用的工具类,但是在具体使用时,标准库文档上对使用 ...

  7. 2&period;2、Android Studio通过注解提升代码检测

    使用像Lint这样的代码检测工具可以帮助你发现问题和提升代码,但是代码检测在有些地方很难应用.例如,Android的资源ID,使用一个int类型来表示字符.图像.颜色或者其他资源类型所以代码检测工具不 ...

  8. linux运维需要掌握什么知识?linux运维学习路线

    linux运维需要掌握什么知识?这个问题算是老生常谈了,但是本人认为知道需要掌握什么知识不是重点,重点是我们需要知道运维是做什么的?再来根据工作需求去讨论需要学习什么知识才是正途,须知知识是学不完的, ...

  9. day07 Python文件操作

    一,文件操作基本流程 #1. 打开文件,得到文件句柄并赋值给一个变量 f=open('a.txt','r',encoding='utf-8') #默认打开模式就为r #2. 通过句柄对文件进行操作 d ...

  10. nginx报错zero size shared memory zone one

    为了限速,在虚拟主机中加上了一个参数:limit_conn one 1:结果导致重启nginx报错: zero size shared memory zone "one"解决办法是 ...