MySql登录
- mysql -uroot -proot \ mysql -uroot -p
- mysql -hip -uroot -p连接目标的密码
- mysql --host=ip --user=root --password=连接目标的密码
Mysql退出
- exit
- quit
MySQL目录结构
- mysql的安装目录
配置文件 my.ini - mysql的数据目录
数据库:文件夹
表:文件
数据:数据
SQL
什么是SQL?
Structured Query Language:结构化查询语言
其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,成为“方言”。
SQL通用语法
- SQL语句可以单行或多行书写,以分号结尾;
- 可以使用空格和缩进来增强语句的可读性;
- MySQL数据库的SQL语句不区分大小写,关键字建议使用大写;
- 3中注释
- 单行注释:- - 注释内容 或 # 注释内容 (注意- -后的空格 )
- 多行注释:/* 注释 */
SQL语句的分类
- DDL:操作数据库和表。关键字:create、drop、alter等
- DML:操作数据库中存储的表中的记录(增删改表中的数据)。关键字:insert、delete、update等。
- DQL:操作数据库中存储的表中的记录(查询表中的数据)。关键字:select、、where等。
- DCL:授权。关键字:GRANT、REMOVKE等。
DDL:操作数据库和表
- 操作数据库:CRUD
1 . Create:创建数据库:
create database 数据库名;
create database if not exists 数据库名; 如果数据库不存在就创建
创建一个数据库db1,判断是否存在,并指定字符集为gbk
create database if not exists db1 character set gbk;
2 . Retrieve(查询)
*查询所有数据库的名称:show database;
*查询某个数据库的字符集:查询某个数据库的创建语句:show create database 数据库名称;
3 . Update(修改)
修改数据库的字符集
alter database 数据库名称 character set 字符集名称;
4 . Delete
drop database 数据库名称;
判断数据库存在与否删除。
drop database if exists 数据库名;
5 . 使用数据库
查询当前正在使用的数据库名称:select database();
使用数据库
use 数据库名称;
- 操作表
1 . C(Create):创建
语法:
create table 表名(列名1 数据类型1,列名2 数据类型2,...列名n 数据类型n);
复制表:create table 表名 like 被复制的表名;
数据类型:
- int:整数类型
- double:小数类型
- date:日期类型
- datetime:时间戳类型,精确到时分秒
- varchar:字符串类型
2 .R(Retrieve):查询
查询数据库中表的名称
*show tables;
查询表结构
*desc 表明;
3 .U(Update):修改
- 修改表名
alter table 表名 rename to 新的表名; - 修改表的字符集
alter table 表名 character set 字符集名称; - 添加一列
alter table 表名 add 列名 数据类型; - 修改列的名称 类型
alter table 表名 change 列名 新列名 新数据类型;
alter table 表名 modify 列名 新数据类型; - 删除列
alter table 表名 drop 列名;
4 .DDelete):删除表
drop table 表名;
drop table if exits 表名;
客户端图形化工具:SQLYoga
安装简单
DML:增删改表中的数据
-
添加数据
语法:sql insert into 表名(列名1,列名2,...,列名n) values(值1,值2,...,值n)
注意:- 列名和值要一一对应
- 如果表名后,不定义列名,则默认给所有列添加值
sql insert into 表名 values(值1,值2,...,值n)
- 除了数字类型,其他类型需要使用引号(单引双引都可以)引起来
-
删除数据
语法格式:sql delete from 表名 [where 条件]
注意:- 如果不加条件,则删除表中的所有记录
2.如果要删除所有记录- delete from 表名;——不推荐使用。有所少条记录就会执行多少次删除操作
- truncate table 表名; ——推荐使用,效率更高。删除表,然后再创建一个一模一样的新表
- 如果不加条件,则删除表中的所有记录
-
修改数据
语法:update 表名 set 列名1 = 值1,列名2 = 值2,...[where 条件]
注意:
如果不加任何条件则会将表中所有数据都修改;
DQL:查询表中的记录
*select * from表名;
- 语法:
select字段列表
from表名列表
where条件列表
group by分组字段
having分组之后的条件
order by排序
limit分页限定
- 基础查询
- 多个字段的查询
select 字段名1,字段名2,...from 表名;
注意:如果查询所有字段,则可以用*代替字段列表 - 去除重复
*distinct - 计算列
*一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
*ifnull(表达式1,表达式2):null参与的运算,计算结果都为null
表达式1:哪个字段需要判断是否为null
如果该字段为null后的替换值 - 起别名
*as:as也可以省略
- 多个字段的查询
- 条件查询
1. where子句后跟条件
2. 运算符
>、<、<=、>=、=、<>
BETWEEN…AND
IN(集合):在集合内的
LIKE:模糊查询。占位符:_单个任意占位符;%:多个任意字符
IS NULL
and 或 &&
or 或 ||
not 或 !
使用:
查询年龄大于20岁
SELECT * FROM student WHERE age > 20;
查询年龄大于等于20小于等于30岁
SELECT * FROM student WHERE age >= 20 && age <= 30;
SELECT * FROM student WHERE age BETWEEN 20 AND 30;
查询年龄22,19,25岁的信息
SELECT * FROM student WHERE age =22 orage =19 or age =25;
SELECT * FROM student WHERE age IN(22,19,25);
查询英语成绩为null
SELECT * FROM student WHERE English IS NULL;
差不为空:IS NOT NULL;
查询姓马的名字
SELECT * FROM student WHERE name LIKE ‘马%’;