MySQL基础及SQL语言常见语法

MySQL基础及SQL语言常见语法

开启关闭服务器以及登录退出客户端

服务器操作
1、开启服务器:net start mysql
2、关闭服务器:net stop mysql
客户端操作
1、登录服务器:mysql -uroot -proot -hlocalhost
-u:用户名
-p:用户名密码
-h:登录IP
2、退出服务器:exit

SQL语言概述

SQL:结构化查询语言(Structured Query Language)
SQL语句分类
1、DDL:数据定义语言,用来定义数据库对象:库、表、列等;
>创建、删除、修改:库、表结构(数据库或表的结构操作)。
2、DML:数据操作语言;
>增、删、改:表记录(对表的记录进行更新)。
3、DCL:数据控制语言,用来定义权限和安全级别(对用户的创建及授权)。
4、DQL:数据查询语言,用来查询记录(数据)。

DDL之操作数据库

1、数据库
查看所有数据库:SHOW DATABASES;
切换数据库:USE 数据库名;
创建数据库:CREATE DATABASE [IF NOT EXISTS] test [CHARSET=utf8];
删除数据库:DROP DATABASE [IF EXISTS] test;
修改数据库编码:ALTER DATABASE test CHARACTER SET utf8。

数据类型介绍1

数据类型(列类型)
int;
double(5,2)(表示最多五位,其中必须两位小数);
decimal,浮点型(表金钱时使用该类型);
char(固定长度字符串类型),数据长度不足指定长度时,补足到指定长度;
varchar(可变长度字符串类型),varchar(65535),需要记录字符串长度;
text(clob):字符串类型;
blob:二进制;
date:日期类型;
time:时间类型;
timestamp:时间戳类型。

DDL之操作表

创建表:CREATE TABLE [IF NOT EXIST] 表名 (
列名 列类型,
列名 列类型,
‘’’
列名 列类型
);
查看当前数据库中所有表名称:SHOW TABLES;
查看指定表的创建语句:SHOW CREATE TABLE 表名;
查看表结构:DESC 表名;
删除表:DROP TABLE 表名;
修改表

  • 修改之添加列:
    ALTER TABLE 列名 ADD (
    列名 列类型,
    列名 列类型,
    );

  • 修改之修改列类型(如果被修改的列已经存在数据,那么新的类型可能会影响到已存在数据):
    ALTER TABLE 表名 MODIFY 列名 列类型;

  • 修改之修改列名:ALTER TABLE 表名 CHANGE 原列名 新列名 列类型;

  • 修改之删除列:ALTER TABLE 表名 DROP 列名;

  • 修改表名称:ALTER TABLE 原表名 RENAME TO 新表名;

DML之INSERT

1.插入数据

INSERT INTO 表名 (列名1,列名2,...) VALUES (列值1,列值2,...);

在表名后给出要插入的列名,没有指定的列等同于插入null值,所以插入记录总是一行,不可能是半行。
在VALUES后给出列值,值的顺序和个数与前面指定的列对应。

2.修改数据

UPDATE 表名 SET 列名1=列值1,列名2=列值2,...[WHERE 条件];

条件必须是一个boolean类型的值或表达式;
运算符:=、!=、<>、>、<、>=、<=、BETWEEN…AND、AND、IS NULL、NOT、OR;

3.删除数据

DELETE FROM 表名 [WHERE 条件];

数据库中的所有字符串类型,必须使用单引号,不能使用双引号。
日期类型也要使用单引号。

插入所有列

INSERT INTO stu ( number, name, age, gender ) VALUES('ITCAST_001','ZHANGSAN',28,'MALE');

不给出插入列,默认插入所有列,值的顺序与创建表时列的顺序相同

INSERT INTO stu VALUES ('ITCAST_003','WANGWU','32','FEMALE');

DCL(数据控制语言)

  • 一个项目创建一个用户!一个项目对应的数据库只有一个!
  • 这个用户只能对这个数据库有权限,其他的数据库无法操作!
  1. 创建用户
CREATE USER 用户名@IP地址 IDENTIFIED BY '密码'>用户只能在指定IP地址登录
 			
CREATE USER 用户名@'%' IDENTIFIED BY '密码';
	>用户可以在任意IP地址登录
  1. 给用户授权
GRANT 权限1,...,权限n,	ON 数据库.* TO 用户名@IP地址;  
GRANT ALL ON test.* TO test@localhost;
	>给用户分配指定数据库上的所有权限;
  1. 撤销授权
REVOKE 权限1,权限2,...,权限3 ON 数据库.* FROM 用户名@IP地址;
  1. 查看权限
SHOW GRANTS FOR 用户@localhost;
  1. 删除用户
DROP USER 用户@localhost;

DQL(数据查询语言)

一、基本查询

1、字段(列)控制

(1)查询所有列

SELECT* FROM 表名;

(2)查询指定列

SELECT1,2 FROM 表名;
SELECT ename,sal FROM emp;

(3)完全重复的记录之显示一次
当查询结果中的多行记录一模一样时,只显示一行,一般查询所有列时很少会有这种情况,但只查询一列是,可能性变大!

SELECT DISTINCT * |1 FROM 表名;

(4)列运算
a.类型可以做四则运算

SELECT *,sal*1.5 FROM emp;

b.转换NULL值

SELECT IFNULL(COMN,0) FROM emp;

c.字符串连接

SELECT CONCAT(ename,job) FROM emp;

d.给列起别名

SELECT ename AS 姓名 FROM emp;

2、条件控制

(1)条件查询

​ SELECT语句也可以使用WHERE子句来控制记录;

SELECT * FROM emp WHERE sal>20000;
SELECT * FROM emp WHERE deptno=20;
SELECT * FROM emp WHERE sal BETWEEN 20000 AND 30000;
SELECT * FROM emp WHERE job in ('Manager','Fenxis');

(2)模糊查询

'_'表示匹配一个任意字符;

SELECT * FROM emp WHERE ename like 'ZhugeLian_';

查询名字为5个字母的人:

SELECT * FROM emp WHERE ename like '______';

'%'表示匹配0-n个任意字符;

SELECT * FROM emp WHERE ename like '%Liang';

二、排序

1、升序

SELECT * FROM emp ORDER BY empno ASC;

升序排序,ASC可以省略。

2、降序

SELECT * FROM emp ORDER BY sal DESC;

DESC不能省略。

3、使用多列作为排序条件

SELECT * FROM emp ORDER BY sal ASC,COMN DESC;

使用sal做升序排列,遇到相同值则使用COMN做降序排列。

三、聚合函数

1、COUNT

SELECT count(*) FROM emp;

计算emp表中所有列都不为空的个数。

2、SUM

SELECT SUM(sal) FROM emp;

计算emp表中sal的总和。

3、MAX

 SELECT MAX(sal) FROM emp;

4、MIN

SELECT MIN(sal) FROM emp;

5、AVG

SELECT AVG(sal) FROM emp;

四、分组查询

SELECT job ,count(*) FROM emp GROUP BY job;

GROUP BY后面跟分组列。

SELECT deptno,COUNT(*) FROM emp WHERE sal>15000 GROUP BY deptno HAVING COUNT(*)>=2;

使用deptno做分组聚合,查询各部门工资大于15000元并且员工个数大于2的部门。

五、limit子句

limit用来限定查询结果的起始行以及总行数。

SELECT * FROM emp LIMIT 0,5;

表示从第0行开始,查询5行记录。

你可能感兴趣的:(MySQL基础及SQL语言常见语法)