美文网首页SQL
MySQL学习笔记---基础概念和一些基础SQL语句(一)

MySQL学习笔记---基础概念和一些基础SQL语句(一)

作者: Omit03 | 来源:发表于2017-02-17 16:29 被阅读84次

    MySQL学习笔记---基础概念和一些基础SQL语句(一)

    作者:zhangjunqiang

    MySQL学习笔记,以防遗忘

    数据库基本概念

    数据库:保存有组织的数据的容器(通常是一个文件或一组文件)。

    表:某种特定类型数据的结构化清单,数据库中的表都有一个唯一的名字用来标识自己。

    模式:关于数据库和表的布局及特性的信息。

    列:表中的一个字段。所有表都是由一个或多个列组成,每个列都有对应的数据类型。

    行:表中的一个记录。

    主键:一列(或一组列),其值能够唯一区分表中每个行(每条记录)。

    任意两行都不具有相同的主键值,每个行都必须具有一个主键值(主键值列不允许NULL值)。

    SQL:一种专门用来与数据库通信的语言,SQL不依赖DBMS的存在而存在。

    MySQL命令

    mysql -user(u) username -password(p) password or none  MySQL登录

    USE databasename; 使用数据库

    SHOW

    SHOW DATABASES;(;可用\g代替):显示当前安装的数据库

    SHOW TABLES; 查看当前数据库中的可用表的列表

    SHOW COLUMNS FROM tablename; 查看某个表中的内容,它对每个字段返回一行,行中包含字段名、数据类型、是否允许NULL、键信息、默认值以及其他信息

    DESCRIBE tablename; 和 SHOW COLUMNS FROM tablename; 具有相同的功能,前者是后者的缩写版。

    SHOW STATUS; 用来显示广泛的服务器状态信息。

    SHOW CREATE DATABASE databasename; 用来显示创建特定数据库的MySQL语句。

    SHOW CREATE TABLE tablename; 用来显示创建特定表的MySQL语句。

    SHOW GRANTS; 用来显示授权用户(所有用户或特定用户)的安全权限。

    SHOW ERRORS; 用来显示服务器错误

    SHOW WARNINGS; 用来显示服务器的警告消息

    SELECT

    SELECT columnname FROM tablename; 用来检索数据表中的coulumnname列中的内容

    SELECT row1,row2... FROM tablename; 用来检索数据表中的row1,row2...行的内容

    SELECT * FROM tablename; *为通配符,用来检索表中的所有列

    SELECT DISTINCT key FROM tablename; 用来检索表中不同值key的行

    SELECT key FROM tablename LIMIT num; 返回key的前num行数据

    SELECT key FROM tablename LIMIT num1,num2; 返回表中key的以num1为起点后num2行

    SELECT tablename.colunname FROM tablename; 用来检索数据表中的coulumnname列中的内容,但是同时列出了表明和列名(完全限定)

    SELECT coulumname FROM tablename ORDER BY key; 以key为导向排序(升序ASC,可省略)

    SELECT coulumname FROM tablename ORDER BY key DESC; 以key为导向排序(降序,注:当有多个key时DESC只作用于直接位于其前面的key)

    SELECT coulumname FROM tablename WHERE condition; 按照条件condition从表中检索指定列中的数据(WHERE子句在FROM子句后给出)

    SELECT coulumname FROM tablename WHERE key BETWEEN c1 AND c2; 从表中检索指定列中在条件c1和c2之间的数据(c1 <= c2)

    SELECT coulumname FROM tablename WHERE key IS NULL; 从表中检索key中为NULL的数据

    操作符

    用来联结或改变WHERE子句中的子句的关键字。

    AND操作符:

    用在WHERE子句中的关键字,用来指示检索满足 所有 给定条件的行。

    OR操作符:

    用在WHERE子句中的关键字,用来表示检索匹配 任一 给定条件的行。

    IN操作符:

    用在WHERE子句中的关键字,用来指定要匹配值的清单的关键字(取合法值的由逗号分割开的清单,全在圆括号中),功能与OR相当。

    NOT操作符:

    用在WHERE子句中的关键字,用来否定它之后所跟的任何条件。

    BETWEEN操作符:

    用在WHERE子句中的关键字,用来检查某个范围的值。

    通配符

    用来匹配值的一部分的特殊字符。为在搜索子句中使用通配符,必须使用LIKE谓词。LIKE指示MySQL后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较。

    %通配符:

    表示任何字符出现的任一次数。

    _通配符:

    下划线通配符 _ 用途与%一样,但下划线只匹配单个字符而不是多个字符。

    通配符使用技巧

    1、不要过度使用通配符。如果其他操作能达到相同的目的,应该使用其他操作符。

    2、在确实需要使用通配符时除非绝对有必要,否则不要把它们用在搜索模式的最开始处,因为这样是最慢的。

    3、仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。

    计算字段

    1、Concat拼接字段:

    把多个串链接起来形成一个较长的串,需要一个或多个指定的串,各个串之间用逗号隔开。

    例如:SELECT Concat(vend_name,'(',vend_country,')') FROM vendors ORDER BY vend_name;

    2、去掉返回的值中的空格:

    (1)、RTrim()去掉右侧多余的空格来整理数据。

    (2)、LTrim()去掉左侧多余的空格来整理数据。

    (3)、Trim()去掉左右两边多余的空格来整理数据。

    3、执行算数运算(MySQL支持 加减乘除运算和圆括号改变运算优先级):

    计算字段另一个用途就是对检索出的数据进行算术计算。

    例如:SELECT prod_id, quantity, item_price, quantity * item_price AS expanded_price FROM orderitems WHERE order_num = 20005;

    事件处理函数

    函数一般是在数据上执行的,它给数据的转换和处理提供了方便。大多数SQL实现支持用于处理文本串的函数、用于在数值数据上进行算术运算操作的函数、用于处理日期和时间并提取特定成分的日期和时间函数、返回DBMS正使用的特殊信息的函数

    1、常见的文本处理函数:

    (1)、Upper(str):将文本str转换为大写。

    例:SELECT Upper(vend_name) AS vend_name_upcase FROM vendors ORDER BY vend_name;

    (2)、Left(str, len):返回串str左边的len个字符。

    例:SELECT Left(vend_name, 3) AS vend_name_upcase FROM vendors ORDER BY vend_name;

    (3)、Length(str):返回串str的长度。

    例:SELECT Length(vend_name) AS vend_name_upcase FROM vendors ORDER BY vend_name;

    (4)、Locate(substr, str):返回串str的一个substr子串的第一个字符出现的位置,如果substr不再str中则返回0。该函数的另一个版本是Locate(substr,str,pos),表示从pos位置开始在str中寻找substr。

    例:SELECT Locate('ACM', vend_name) FROM vendors ORDER BY vend_name;

    注意:

    1、ORDER BY子句必须位于FROM子句之后。

    2、当ORDER BY 子句和LIMIT子句同时使用时LIMIT子句必须位于ORDER BY子句之后。

    3、同时使用WHERE子句和ORDER BY子句时应将ORDER BY子句置于WHERE子句之后。

    4、WHERE子句支持 =、>、<、!=、<>(不等于)、>=、<=、BETWEEN(指定的两个值之间)过滤操作。

    5、AND和OR操作符混合使用时要注意AND操作符的计算次序比OR操作符号的计算次序要高(操作符优先级高),所以一般有多个操作符时要加上圆括号消除歧义(即使不这样做也是正确的)

    6、MySQL支持使用NOT对IN、BETWEEN和EXISTS子句取反(其他DBMS允许使用NOT对各种条件取反)。

    7、尾空格可能会干扰通配符匹配,例如:'%anvil'如果anvil后有一个空格则不会被匹配出来。可使用'%anvil%'或者使用函数解决此问题。

    8、%通配符不会匹配到NULL。

    9、SELECT语句的拼接完成的列是没有名字的,它只是一个值,这种是无法在客户机中直接使用的,所以可以用AS关键字赋予一个别名(也称为导出列)。

    例如:SELECT Concat(vend_name,'(',vend_country,')') AS vend_title FROM vendors ORDER BY vend_name;

    聚集函数:

    运行在行组上,计算和返回单个值的函数(需要汇总数据而不需要检索出来)

    ACG(column):返回某列的平均值。

    COUNT(column):返回某列的行数。COUNT(*):返回所有列的和。

    MIN(column):返回某列的最小值。

    MAX(column):返回某列的最大值。

    SUM(column):返回某列的和。

    DISTINCT:只包含不同值

    分组:

    分组允许把数据分为多个逻辑组,以便能对每个组进行聚集计算。

    创建分组:GROUP BY子句,GROUP BY子句必须出现在WHERE子句之后,ORDER BY子句之前。

    WITH ROLLUP:可以得到每个分组汇总级别的值(和ORDER BY子句互斥)。

    HAVING:HAVING过滤分组,WHERE过滤列,HAVING位于GROUP BY子句之前,HAVING位于GROUP BY子句之后。(WHERE在分组前进行过滤,HAVING在分组后进行过滤)

    GROUP BY和ORDER BY子句的区别:

    1、OEDER BY是排序后的输出而GROUP BY是分组的顺序(不一定是期望输出的顺序)

    2、ORDER BY任意列都可以使用,而GROUP BY只可能使用选择列或表达式列,而且必须使用每个选择列表达式。

    3、ORDER BY不是必须出现在SQL语句中,但是如果与聚集函数一起使用列(或表达式)GROUP BY子句必须存在于SQL语句中。

    SELECT 子句顺序:

    子查询:

    嵌套在其他查询中的查询。如:

    SELECT cust_name

    FROM customers

    WHERE cust_id IN

    (

    SELECT cust_id

    FROM orders

    WHERE order_num IN

    (

    SELECT order_num

    FROM orderitems

    WHERE prod_id = 'TNT2'

    )

    );

    一些概念

    完全限定:表名.列名

    相关子查询:涉及外部查询的子查询

    关系表:将不同数据分别存储在不同数据表中,用相应的关系进行连接。

    主键:每个表都有一个唯一的标识。

    外键:某个表的一列,包含另一个表的主键值。

    相关文章

      网友评论

        本文标题:MySQL学习笔记---基础概念和一些基础SQL语句(一)

        本文链接:https://www.haomeiwen.com/subject/iirlwttx.html