MYSQL数据库软件
数据库登陆
# 本地登陆
mysql -uroot -p密码
# 远程登陆,两种
mysql -hip -Pport -uroot -p密码
mysql --h=ip --P=port --u=root --p=密码
数据库目录结构(mac上的稍后处理)
- mysql安装目录
- mysql数据目录
SQL的概念
什么是sql?
Structured Query Language :结构化查询语言
其实就是定义了所有操作关系型数据库的规则
SQL通用语法
- SQL语句可以单行或多行书写, 以分号结尾;
- 可以使用空格和缩进增加可读性;
- MYSQL数据库的SQL语句不区分大小写,但关键字建议用大写;
- 注释:
单行注释使用 – 注释内容 或 # 注释内容(后者为MYSQL特有)
多行注释使用 /* */
SQL分类
- DDL(操作数据库和表)
- DML(增删改表中的记录)
- DQL(查询表中的记录)
- DCL(授权处理)
DDL:操作数据库、表
一、操作数据库:CRUD
1、C(create):创建
* 创建数据库
create database 数据库名称;
* 创建数据库,判断是否存在
create database if not exists 数据库名称;
* 创建数据库,并指定字符集
create database 数据库名称 chatacter set gk;
* 创建一个db4的数据库,判断是否存在,并指定字符集为gbk
create database if not exists db4 character set gbk;
2、R(retrieve):
* 查询所有数据库的名称
show databases;
* 查询某个数据库的字符集:查询某个数据库的创建语句
show create database 数据库名称;
3、U(update):修改
* 修改数据库的字符集
* alter database 数据库名称 character set 字符集名称;
4、D (delete):删除
* 删除数据库
* drop database 数据库名称;
* 删除数据库,如果数据库存在
* drop database if exists 数据库名称;
5、使用数据库
* 查询当前正在使用的数据库名称
* select database();
* 使用数据库
* use 数据库名称;
二、操作表
1、C(create):创建
* 创建数据库
create table 表名(
列名1 数据类型1,
列名2 数据类型2,
列名3 数据类型3,
列名4 数据类型4
);
* 注意:最后一列,不需要加逗号(,)
* 数据类型:
1、int:整数类型
* age int,
2、double:小数类型
* score double(5,2)
3、date:日期,只包含年月日,yyyy-MM-dd
4、datetime:日期,包含年月日时分秒,yy-MM-dd HH:mm:ss
5、timestamp:时间戳类型,包含年月日时分秒,yy-MM-dd HH:mm:ss
* 如果不给这个字段赋值或者赋值为 null,则默认使用当前的系统时间,来自动赋值
6、varchar:字符串类型
* name varchar(20):表示姓名最大长度为20个字符
* zhangsan 8个字符 张三 2个字符
* 创建一张学生表
create table student(
id int,
name varchar(32),
age int,
score double(4,1),
birthday date,
insert_time timestamp
);
* 创建表,判断是否存在
create table if not exists 表名称;
* 复制一个表
create table 表名 like 原始表;
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、D (delete):删除
* 删除表
* drop table 表名称;
* 删除表,如果表存在
* drop table if exists 表名称;
DML
1. 添加数据
* 语法
* insert into 表名(列名1,列名2,... ,列名n ) values (值1, 值2,... , 值n);
* 注意:
- 列名和值要一一对应
- 如果表名后,不定义列名,则默认给所有列添加值
- 除了数字类型,其他类型需要使用引号引起来(单双引号都可以)
2. 删除数据
* 语法:
* delete from 表名 where 条件;
* 注意:
- 如果不加条件,则会删除表中的所有记录;
- 如果要删除表中所有数据:
* truncate table 表名; -- 删除表,然后再创建一个相同的空表
* delete from 表名; -- 不建议使用,有多少数据就执行多少次
3. 修改数据
* 语法:
* update 表名 set 列名1=值1,列名2=值2,... [where 条件 ];
* 注意:
1、如果不加任何条件,会将表中的数据全部修改掉。