MySQL 学习随笔

来源:互联网 发布:联通语音网络类型 编辑:程序博客网 时间:2024/06/06 07:40

distinct

用于返回唯一不同的值.
语法:

SELECT DISTINCT 列名称 FROM 表名称

where

有条件的从表中选取数据
语法:

SELECT 列名称 FROM 表名称 WHERE 列 运算符 值
=   等于<>  不等于>   大于<   小于>=  大于等于<=  小于等于BETWEEN 在某个范围内LIKE    搜索某种模式

and or

AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。
如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录。
如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。
语法

SELECT * FROM Persons WHERE (FirstName='Thomas' OR FirstName='William')AND LastName='Carter'

ORDER BY 排序##

ORDER BY 语句用于根据指定的列对结果集进行排序。
ORDER BY 语句默认按照升序对记录进行排序。
如果您希望按照降序对记录进行排序,可以使用 DESC 关键字。
语法:

SELECT 列名称 FROM 表名称 ORDER BY 列名称 ;SELECT 列名称 FROM 表名称 ORDER BY 列名称 desc ; 降序

INSERT INTO

INSERT INTO 语句用于向表格中插入新的行。
语法:

INSERT INTO 表名称 VALUES (值1, 值2,....)我们也可以指定所要插入数据的列:INSERT INTO 表名称(列1, 列2,...) VALUES (值1, 值2,....)

update

Update 语句用于修改表中的数据。
语法:

UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值

delete

DELETE 语句用于删除表中的行。
语法:

DELETE FROM 表名称 WHERE 列名称 = 值

Like

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。
语法:

SELECT 列名称FROM 表名称    WHERE  列名称 LIKE pattern

通配符

这里写图片描述


In

IN 操作符允许我们在 WHERE 子句中规定多个值。
语法:

SELECT 列名称FROM 表名称WHERE 列名称 IN (value1,value2,...)

between

操作符 BETWEEN … AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。
语法:

SELECT 列名称 FROM 表名称 WHERE 列名称 BETWEEN 值1(包含) AND2(包含) 

NOT

SELECT * FROM PersonsWHERE LastNameNOT BETWEEN 'Adams' AND 'Carter'

Alias

可以为列名称和表名称指定别名
语法:
表的 SQL Alias 语法

SELECT column_name(s)FROM table_nameAS alias_name

列的 SQL Alias 语法

SELECT column_name AS alias_nameFROM table_name

join

用于根据两个或多个表中的列之间的关系,从这些表中查询数据。
inner join : 内连接: 取得两个表中存在连接匹配关系的记录。
cross join : 交叉连接: 在不指定 ON 条件下得到的结果是被连接的两个数据表的乘积,即笛卡尔积。
left join : 左连接: 取得左表(table1)完全记录,即是右表(table2)并无对应匹配记录。
right join : 右连接: 与 LEFT JOIN 相反,取得右表(table2)完全记录,即是左表(table1)并无匹配对应记录。

实际上,在 MySQL 中(仅限于 MySQL) CROSS JOIN 与 INNER JOIN 的表现是一样的,在不指定 ON 条件得到的结果都是笛卡尔积,反之取得两个表完全匹配的结果。
INNER JOIN 与 CROSS JOIN 可以省略 INNER 或 CROSS 关键字,因此下面的 SQL 效果是一样的:
… FROM table1 INNER JOIN table2
… FROM table1 CROSS JOIN table2
… FROM table1 JOIN table2
语法:

SELECT 列名称 FROM1 JOIN2 ON 条件

union

UNION 操作符用于合并两个或多个 SELECT 语句的结果集。
请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同
语法:

SELECT column_name(s) FROM table_name1UNIONSELECT column_name(s) FROM table_name2

UNION 操作符选取不同的值。如果允许重复的值,请使用 UNION ALL。


select into

SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中。
SELECT INTO 语句常用于创建表的备份复件或者用于对记录进行存档。
语法:

SELECT *INTO new_table_name [IN externaldatabase] FROM old_tablename或者只把希望的列插入新表:SELECT column_name(s)INTO new_table_name [IN externaldatabase] FROM old_tablename

CREATE DATABASE

CREATE DATABASE 用于创建数据库。
语法:

CREATE DATABASE database_name

CREATE TABLE

CREATE TABLE 语句用于创建数据库中的表。
语法

CREATE TABLE 表名称(列名称1 数据类型,列名称2 数据类型,列名称3 数据类型,....)

NOT NULL 约束

NOT NULL 约束强制列不接受 NULL 值。

SQL UNIQUE 约束

UNIQUE 约束唯一标识数据库表中的每条记录
UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
PRIMARY KEY 拥有自动定义的 UNIQUE 约束。
请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。

PRIMARY KEY 约束

PRIMARY KEY 约束唯一标识数据库表中的每条记录。
主键必须包含唯一的值。
主键列不能包含 NULL 值。
每个表都应该有一个主键,并且每个表只能有一个主键。

SQL FOREIGN KEY 约束

一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。

CHECK 约束

CHECK 约束用于限制列中的值的范围。

DEFAULT 约束

DEFAULT 约束用于向列中插入默认值。


CREATE INDEX

CREATE INDEX 语句用于在表中创建索引。
在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据。
语法

CREATE INDEX index_nameON table_name (column_name)

DROP

删除索引、表和数据库
删除表格中的索引语法:

ALTER TABLE table_name DROP INDEX index_name

DROP TABLE 语句用于删除表(表的结构、属性以及索引也会被删除):

DROP TABLE 表名称

DROP DATABASE

DROP DATABASE 数据库名称

TRUNCATE TABLE 语句,仅仅删除表格中的数据

TRUNCATE TABLE 表名称

ALTER

用于在已有的表中添加、修改或删除列。
语法

如需在表中添加列,请使用下列语法:ALTER TABLE table_nameADD column_name datatype要删除表中的列,请使用下列语法:ALTER TABLE table_name DROP COLUMN column_name

view

视图是基于 SQL 语句的结果集的可视化的表
创建视图
语法:

CREATE VIEW view_Name AS SELECT 列名称 FROM 表名称 WHERE 条件

更新视图
语法:

create or replace view view_name as select 列名称 from 表名称 where 条件

查询视图
语法:

SELECT * FROM view_Name

date 函数

NOW()   返回当前的日期和时间CURDATE()   返回当前的日期CURTIME()   返回当前的时间DATE()  提取日期或日期/时间表达式的日期部分EXTRACT()   返回日期/时间按的单独部分DATE_ADD()  给日期添加指定的时间间隔DATE_SUB()  从日期减去指定的时间间隔DATEDIFF()  返回两个日期之间的天数DATE_FORMAT()   用不同的格式显示日期/时间

IS NULL IS NOT NULL

SELECT 列名称 FROM 表名称 WHERE 列名称 IS NULL SELECT 列名称 FROM 表名称 WHERE 列名称 IS NOT NULL 

AVG()

函数返回数值列的平均值。NULL 值不包括在计算中。

SELECT AVG(列名称) FROM 表名称

count

函数返回匹配指定条件的行数
语法:

SELECT COUNT(列名称) FROM 表名称 :函数返回指定列的值的数目SELECT COUNT(*) FROM 表名称:函数返回表中的记录数SELECT COUNT(DISTINCT 列名称) from 表名称:函数返回指定列的不同值的数目:

例子:
这里写图片描述

1.计算客户 “Carter” 的订单数

SELECT COUNT(Customer)  FROM OrdersWHERE Customer='Carter'结果为2 

2.

SELECT COUNT(*) AS NumberOfOrders FROM Orders结果为6

3.计算 “Orders” 表中不同客户的数目

select count(distinct Customer) from orders 结果为3

FIRST()

返回指定的字段中第一个记录的值

SELECT FIRST(column_name) FROM table_name

LAST()

LAST() 函数返回指定的字段中最后一个记录的值。

SELECT LAST(column_name) FROM table_name

MAX

返回一列中的最大值。NULL 值不包括在计算中。

SELECT MAX(column_name) FROM table_name

MIN

返回一列中的最小值。NULL 值不包括在计算中。

SELECT MIN(column_name) FROM table_name

SUM

回数值列的总数(总额)。

SELECT SUM(column_name) FROM table_name

GROUP BY

语句用于结合合计函数,根据一个或多个列对结果集进行分组。

select column_name ,合计函数() from table_name where 条件 group by column_name 

having

和where 差不多,但是having可以和合计函数一起用.
错误用法:

select sum(column_name) from table_name where avg(column_name) > 0

正确用法

select sum(column_name) from table_name where 条件 having avg(column_name) > 0

UCASE()

把字段的值转换为大写。
语法:

select ucase(column_name) from table_name

LCASE()

把字段的值转换为小写.
语法:

select lcase(column_name) from table_name 

MID()

用于从文本字段中提取字符。
语法:

SELECT MID(City,1,3) as SmallCity FROM Persons

len()

返回文本字段中值的长度。

SELECT LEN(column_name) FROM table_name

ROUND()

用于把数值字段舍入为指定的小数位数。

SELECT ROUND(column_name,decimals) FROM table_namecolumn_name 必需。要舍入的字段。decimals    必需。规定要返回的小数位数。

NOW()

返回当前的日期和时间

select now() from table_name

FORMAT()

对字段的显示进行格式化。

SELECT FORMAT(column_name,format) FROM table_namecolumn_name 必需。要格式化的字段。format  必需。规定格式。例子:SELECT ProductName, UnitPrice, FORMAT(Now(),'YYYY-MM-DD') as PerDateFROM Products

case when then end

case _name when '张三' then '张大三' else '无名氏' end case when _name = '张三' then '张大三' else '无名氏' end
原创粉丝点击