数据库:用于存储和管理数据的仓库。
数据库的特点:
1.持久化存储数据。其实数据库就是一个文件系统
2.方便存储和管理数据
3.使用了统一的方式操作数据库。--SQL
常用数据库:MYSQL(免费、开源)、Oracle
MySQL服务启动:
cmd--> services.msc 打开服务的窗口
以管理员身份运行cmd
启动服务:net start mysql
停止服务:net stop mysql
MySQL登录和退出:
登录:mysql -uroot -proot
mysql -hip -uroot -p链接目标密码
mysql --host=127.0.0.1 --user=root --password=root
MySQL退出:exit或者quit
MySQL目录结构:
1.MySQL安装目录
配置文件: my.ini
2.MySQL数据目录
数据库 :文件夹
表:文件
数据:文件中存储的数据
什么是SQL?
Structured Query Language:结构化查询语言
其实就是定义了操作所以关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,称为“方言”。
SQL通用语法:
1.SQL语句可以单行或者多行书写,以分号结尾。
2.可以使用空格和缩进提高程序的可读性。
3.MySQL数据库的SQL语句不区分大小写,关键字建议使用大写
4.三种注释
单行注释: -- 注释内容 或者 # 注释内容(MySQL特有)
多行注释:/* 注释 */
SQL分类:
DDL:Data Difinition Language 数据定义语言,一般用来库和表头的创建和删除;
DML:Data Manipulation Language 数据操作语言,一般用来做表中数据的增加、删除和修改;
DQL:Data Query Language 数据查询语言,用来在数据库中查询的语言,select就在这里;
DCL:Data Control Language 数据控制语言,一般是DBA才会用到的数据库用户管理及日常维护语言。
DDL:操作数据库和表
1.操作数据库:CRUD
C(Create):创建
创建数据库:
create database 数据库名称;
创建数据库,判断不存在:
create database if not exists 数据库名称;
创建数据库,并指定字符集:
create database 数据库名称 character set 字符集名称;
练习:创建一个db4数据库,判断是否存在,并指定字符集为gbk:
create database if not exists db4 character set gbk;
R(Retrieve):查询
查询所有数据库的名称:show databases;
查看某个数据库的字符集(查询某个数据库的创建语句):show create database 数据库名称;
U(Update):修改
修改数据库的字符集
alter database 数据库名称 character set 字符集名称;
D(Delete):删除
删除数据库
drop database 数据库名称;
判断数据库存在,存在再删除
drop database if exists 数据库名称;
使用数据库:
查询当前正在使用的数据库名称: select database();
使用数据库:use 数据库名称;
2.DDL操作表
C(Create):创建
语法:
create table 表名(
列名1 数据类型1,
列名2 数据类型2,
...
列名n 数据类型n
);
注意最后一列不需要加逗号(,)
数据库类型:
int :整数类型 如 age int,
double:小数类型 如 score double(5,2), 长度最大为5,精度为2
date:日期类型,只包含年月日的日期,格式yyyy-MM-dd
datetime:日期,包含年月日时分秒 yyyy-MM-dd HH:mm-ss
timestamp:时间戳类型,包含年月日时分秒 yyyy-MM-dd HH:mm-ss
和datetime区别:如果将来不给这个字段赋值,或者赋值为null,则默认使用当前系统时间赋值。
varchar:字符串 name varchar(20):姓名最大20个字符
创建表
create table student(
id int,
name varchar(32),
age int,
score double(4,1),
birthday date,
insert_time timestamp
);
复制表:create table 表名 like 被复制的表名;
R(Retrieve):查询
查询某个数据库中所有表名称:show tables;
查询表结构:desc 表名;
show tables;
U(Update):修改
修改表名: alter table 表名 rename to 新的表名;
修改表的字符集: alter table 表名 character set 字符集名称;
添加一列:alter table 表名 add 列名 数据类型;
修改列的名称 类型:
alter table 表名 change 列名 修改后的新列名 新数据类型;
alter table 表名 modify 列名 新数据类型;
删除列: alter table 表名 drop 列名;
D(Delete):删除
drop table 表名;
drop table if exists 表名;
客户端图形化工具:SQLYog
SQLyog-12.0.9-0.x64 下载地址
链接:https://pan.baidu.com/s/1WI70PwRQCyqPWI4OvSIBrw
提取码:g6gm
内含激活码,自行激活注册。
DML:增删改表中数据
1.添加数据:
语法:insert into 表名(列名1,列名2,...列名n) values(值1,值2, ...值n);
注意:列名和值要一一对应
如果表名后,不定义列名,则默认给所有列添加值。
insert into 表名 values(值1,值2, ...值n);
除了数字类型,其他类型需要用引号(单双引号都可以)引起来。
2.删除数据
delete from 表名 [where 条件];
注意:如果不加条件,则删除表中所有记录。
如果要删除所有记录
delete from 表名; -- 不推荐使用。有多少条记录就会执行多少次删除操作。
TRUNCATE TABLE 表名; -- 先删除表,然后再创建一个一模一样的空表。效率更高,推荐使用。
3.修改数据:
语法:update 表名 set 列名1=值1,列名2=值2,......[where 条件];
注意:如果不加任何条件,则会将表中记录全部进行修改。
DQL:查询表中的记录
select * from 表名;