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(包含) AND 值2(包含)
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 列名称 FROM 表1 JOIN 表2 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
- PHP MYSQL 学习随笔
- mysql学习随笔
- Mysql学习随笔
- MySQL 学习随笔
- mysql存储过程学习随笔
- mysql存储过程学习随笔(2)
- mysql随笔
- mySQL 随笔
- mysql随笔
- mysql随笔
- MySQL随笔
- mysql 随笔
- mysql随笔
- MySQL随笔
- Mysql随笔
- 学习随笔
- 学习随笔
- 学习随笔
- NYOJ99 欧拉图
- plsql远程连接数据库
- Facebook SDE onsite面经
- 链表中倒数第k个节点(剑指Offer 第14 题)
- 对线性回归、逻辑回归、各种回归的概念学习
- MySQL 学习随笔
- C++笔试题(十五).富途证券 & 猎豹移动 & TP-LINK
- 【STL】容器调用时机
- Uva10791 质因数分解
- JS的设计模式
- 【STL】常用算法
- sdnu1007
- Visual Studio 2017 编译器的安装与最基本使用
- Python-设计模式