SQL语言

2.1 概述

    SQL:Structure Query Language(结构化查询语言),SQL被美国国家标准局(ANSI)确定为关 系型数据库语言的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语言的国际标准。 各数据库厂商都支持ISO的SQL标准,普通话 各数据库厂商在标准的基础上做了自己的扩展,方言 SQL 是一种标准化的语言,它允许你在数据库上执行操作,如创建项目,查询内容,更新内容, 并删除条目等操作。 Create, Read, Update, and Delete 通常称为CRUD操作。

2.2 SQL语句分类

- DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等。

- DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据)增删改。

- DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别。

- DQL(Data Query Language):数据查询语言,用来查询记录(数据)查询。

注意:sql语句以;结尾 mysql中的关键字不区分大小写

2.3 DDL操作数据库

1 创建

CREATE DATABASE语句用于创建新的数据库:

编码方式:gb2312,utf-8,gbk,iso-8859-1

//create database 数据库名
CREATE DATABASE mydb1;
//create database 数据库名 character set 编码方式
CREATE DATABASE mydb2 character SET GBK;
//create database 数据库名 set 编码方式 collate 排序规则
CREATE DATABASE mydb3 character SET GBK COLLATE gbk_chinese_ci;

2查看数据库

查看当前数据库服务器中的所有数据库

show databases;

查看前面创建的mydb2数据库的定义信息

//show create database 数据库名;
Show CREATE DATABASE mydb2;

3 修改数据库

alter database 数据库名 character set 编码方式

查看服务器中的数据库,并把mydb2的字符集修改为utf8;

ALTER DATABASE mydb2 character SET utf8;

4 删除数据库

drop database 数据库名

DROP DATABASE mydb3;

5 其他语句

查看当前使用的数据库

Select database();

切换数据库: use 数据库名

USE mydb2;

2.4 DDL操作表

CREATE TABLE语句用于创建新表。

语法:

CREATE TABLE 表名(
列名1 数据类型 [约束],
列名2 数据类型 [约束],
列名n 数据类型 [约束]
);

说明:表名,列名是自定义,多列之间使用逗号间隔,最后一列的逗号不能写 [约束] 表示可有可无

常用数据类型:

int:整型

double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为 999.99;默认支持四舍五入

char:固定长度字符串类型; char(10) 'aaa ' 占10位

varchar:可变长度字符串类型; varchar(10) 'aaa' 占3位

text:字符串类型,比如小说信息;

blob:字节类型,保存文件信息(视频,音频,图片);

date:日期类型,格式为:yyyy-MM-dd;

time:时间类型,格式为:hh:mm:ss timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值 datetime:日期时间类型 yyyy-MM-dd hh:mm:ss

2.4.1 其他表操作

drop table 表名;

DROP TABLE table_name;

当前数据库中的所有表

SHOW TABLES;

查看表的字段信息

desc 表名;

DESC employee;

增加列:在上面员工表的基本上增加一个image列。

alter table 表名 add 新列名 新的数据类型

ALTER TABLE employee ADD image blob;

修改job列,使其长度为60。

alter table 表名 change 旧列名 新列名 新的数据类型

ALTER TABLE employee MODIFY job varchar(60);
ALTER TABLE employee change job job varchar(60);

列名name修改为username

ALTER TABLE user CHANGE name username varchar(100);

删除image列,一次只能删一列。

alter table 表名 drop 列名

ALTER TABLE employee DROP image;

修改表名,表名改为user。 alter table 旧表名 rename 新表名;

alter table user rename users;

查看表格的创建细节

show create table 表名;

SHOW CREATE TABLE user;

修改表的字符集为gbk

alter table 表名 character set 编码方式

ALTER TABLE user CHARACTER SET gbk;

2.5 DML操作

DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。 主要包括:INSERT 、UPDATE、 DELETE

(1)插入操作:INSERT: insert into 表名(列名) values(数据值);

insert into student(stuname,stuage,stusex,birthday) values('张三1',18,'a','2000-
1-1');

同时添加多行 insert into 表名(列名) values(第一行数据),(第二行数据),(),();

insert into student(stuname,stuage,stusex,birthday)
values('张三3',18,'a','2000-1-1'),
('张三4',18,'a','2000-1-1'),
('张三5',18,'a','2000-1-1'),
('张三6',18,'a','2000-1-1'),
('张三7',18,'a','2000-1-1'),
('张三8',18,'a','2000-1-1');

sql中的运算符:

(1)算术运算符:+,-,*,/(除法),求余(%) 示例: 5/2 5%2 2/5 2%5

(2)赋值运算符:=   注:赋值方向:从右往左赋值 示例: name='张三'

(3) 逻辑运算符: and(并且),or(或者),not(取非) 作用:用于连接多个条件时使用

(4) 关系运算符: >,=,(不等于) 补充:查询所有数据:select * from 表名

(2)修改(更新)操作:UPDATE: 语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 ... WHERE 列名=值

(3)删除操作:DELETE: 语法 : DELETE from 表名 【WHERE 列名=值】

- DELETE 删除表中的数据,表结构还在;删除后的数据可以找回

- TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。

- 删除的数据不能找回。执行速度比DELETE快。

获取当前系统时间:now()

select now();

2.6 DCL

1、创建用户: create user 用户名@指定ip identified by 密码;

create user test123@localhost IDENTIFIED by 'test123'

create user 用户名@客户端ip identified by 密码; 指定IP才能登陆

create user [email protected] IDENTIFIED by 'test456'

create user 用户名@‘% ’ identified by 密码 任意IP均可登陆

create user test7@'%' IDENTIFIED by 'test7'

2、用户授权: grant 权限1,权限2,........,权限n on 数据库名.* to 用户名@IP; 给指定用户授予指定指定数据库指定权限

grant select,insert,update,delete,create on
chaoshi.* to 'test456'@'127.0.0.1';

grant all on . to 用户名@IP 给指定用户授予所有数据库所有权限

grant all on *.* to 'test456'@'127.0.0.1'

3、用户权限查询: show grants for 用户名@IP;

show grants for 'root'@'%';

4、撤销用户权限: revoke 权限1,权限2,........,权限n on 数据库名.* from 用户名@IP;

REVOKE SELECT ON *.* FROM 'root'@'%' ;

5、删除用户: drop user 用户名@IP;

drop user test123@localhost;

第三章 DQL数据查询

DQL数据查询语言(重要)

数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

查询返回的结果集是一张虚拟表。

查询关键字:SELECT 语法: SELECT 列名 FROM 表名 【WHERE --> BROUP BY-->HAVING--> ORDER BY】

3.1 简单查询

查询所有列

SELECT * FROM stu;

查询指定列

SELECT sid, sname, age FROM stu;

3.2 条件查询

条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字: =、!=、<>、、>=; BETWEEN…AND; IN(set); IS NULL; AND;OR; NOT;

(1)查询性别为女,并且年龄50以内的记录

SELECT * FROM stu WHERE gender='female' AND age<50;

(2)查询学号为S_1001,或者姓名为liSi的记录

SELECT * FROM stu WHERE sid ='S_1001' OR sname='liSi';

(3)查询学号为S_1001,S_1002,S_1003的记录 列名 in (列值1,列值2)

SELECT * FROM stu WHERE sid IN ('S_1001','S_1002','S_1003');

(4)查询学号不是S_1001,S_1002,S_1003的记录

SELECT * FROM tab_student WHERE sid NOT IN('S1001','S1002','S_1003');

(5)查询年龄为null的记录

SELECT * FROM stu WHERE age IS NULL;

(6) 查询年龄在20到40之间的学生记录

SELECT * FROM stu WHERE age>=20 AND age<=40;

或者:列名 between 开始值 and 结束值;//注意:1.开始值<结束值 2.包含临界值的

SELECT * FROM stu WHERE age BETWEEN 20 AND 40;

(7) 查询性别非男的学生记录

SELECT * FROM stu WHERE gender!='male';

或者

SELECT * FROM stu WHERE gender<>'male';

或者

SELECT * FROM stu WHERE NOT gender='male';

(8) 查询姓名不为null的学生记录

SELECT * FROM stu WHERE NOT sname IS NULL;

或者

SELECT * FROM stu WHERE sname IS NOT NULL;

3.3 模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE。

语法: 列名 like '表达式' //表达式必须是字符串

通配符:

_(下划线): 任意一个字符

%:任意0~n个字符,'张%'

(1)查询姓名由3个字构成的学生记录

SELECT * FROM stu WHERE sname LIKE '___';

模糊查询必须使用LIKE关键字。其中 “”匹配任意一个字,3个“”表示3个任意字。

(2)查询姓名由5个字母构成,并且第5个字母为“i”的学生记录

SELECT * FROM stu WHERE sname LIKE '____i';

(3)查询姓名以“z”开头的学生记录

SELECT * FROM stu WHERE sname LIKE 'z%';

其中“%”匹配0~n个任何字母。

SELECT * FROM stu WHERE sname LIKE '_i%';

(4)查询姓名中第2个字母为“i”的学生记录

SELECT * FROM stu WHERE sname LIKE '_i%';

(5)查询姓名中包含“a”字母的学生记录

SELECT * FROM stu WHERE sname LIKE '%a%';

3.4 字段控制查询

(1)去除重复记录

去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的 记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用 DISTINCT:

SELECT DISTINCT sal FROM emp;

(2)查看雇员的月薪与佣金之和

因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不 是数值类型,那么会出错。

SELECT *,sal+comm FROM emp;

comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出 现NULL。下面使用了把NULL转换成数值0的函数IFNULL:

SELECT *,sal+IFNULL(comm,0) FROM emp;

(3)给列名添加别名

在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为 total:

SELECT *, sal+IFNULL(comm,0) AS total FROM emp;

给列起别名时,是可以省略AS关键字的:

ELECT *,sal+IFNULL(comm,0) total FROM emp;

3.5 排序

语法: order by 列名 asc/desc

//asc 升序 desc 降序 默认不写的话是升序

(1) 查询所有学生记录,按年龄升序排序

SELECT *
FROM stu
ORDER BY age ASC;

或者

SELECT *
FROM stu
ORDER BY age;

(2) 查询所有学生记录,按年龄降序排序

SELECT *
FROM stu
ORDER BY age DESC;

(3) 查询所有雇员,按月薪降序排序,如果月薪相同时,按编号升序排序 多列排序:当前面的列的值相同的时候,才会按照后面的列值进行排序

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

3.6 聚合函数

聚合函数是用来做纵向运算的函数:

COUNT(列名):统计指定列不为NULL的记录行数;

MAX(列名):计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算; MIN(列名):计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算; SUM(列名):计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;

AVG(列名):计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

(1) COUNT 当需要纵向统计时可以使用COUNT()。 查询emp表中记录数:

SELECT COUNT(*) AS cnt FROM emp;

查询emp表中有佣金的人数:

SELECT COUNT(comm) cnt FROM emp;

注意,因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数。

SQL语言_第1张图片

SQL语言_第2张图片

SQL语言_第3张图片

SQL语言_第4张图片

 

你可能感兴趣的:(SQL语言)