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

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'

)

);

一些概念

完全限定:表名.列名

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

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

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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 关系型数据库和SQL SQL语言的三个部分DML:Data Manipulation Language,数据操纵语...
    Awey阅读 1,937评论 0 13
  • 50个常用的sql语句Student(S#,Sname,Sage,Ssex) 学生表Course(C#,Cname...
    哈哈海阅读 1,224评论 0 7
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,699评论 0 2
  • 经典MSSQL语句大全和常用SQL语句命令的作用 下列语句部分是Mssql语句,不可以在access中使用。 SQ...
    Keropok阅读 2,392评论 0 30
  • 2017.10.9 #199 日月杂交记 14:35pm-11:20am 今天奉节天气晴好,穿着短袖很是凉爽,这会...
    少年阿段阅读 151评论 0 0