数据库概述
什么是数据库?
所谓的数据库就是指存储和管理数据的仓库
早期: 层次式数据库、网络型数据库
现在:关系型数据库、非关系型数据库
什么是关系型数据库?
底层以二维表的形式保存数据的库就是关系型数据库
学生编号 | 姓名 | 年龄 |
---|---|---|
1001 | 张三 | 35 |
1002 | 李四 | 18 |
常见的关系型数据库有哪些?(了解)
-
Sql Server:微软提供,收费,适用于一些中型或大型的项目中,在java中的使用占比不高(.NET中使用的较多)
-
Oracle:甲骨文公司提供,收费,适用于一些大型或者超大型的项目中,在java中的使用占比非常高
-
mysql:瑞典MySQLAB公司提供,免费开源,适用于一些小型或者中型的项目中,在Java中的使用占比较高(小巧轻量)
mariadb其实就是MySQL的一个分支,用法和MySQL完全一样。 -
DB2:IBM公司提供,收费,在一些银行、金融等行业中使用较多。在java中的使用占比也不高。
-
Sqlite:迷你数据库,嵌入式设备中(安卓、苹果手机、pad)
1、什么是数据库服务器
数据库服务器就是一个软件(比如mysql软件)将数据库软件安装在电脑上,当前电脑就是一个数据库服务器。就可以对外提供存取数据的服务
在一个数据库服务器中可以创建多个数据库(dataBases),每一个数据库都是一个单独的仓库。
2、什么是数据库
数据库就是存储和管理数据的仓库,通常情况下,一个网站的中的所有数据会存放在一个数据库中。
3、什么是表
一个数据库中可以创建多张表,每张表用于存储一类信息(数据库)
4、什么表记录·
一张表中可以包含多行表记录,每一行表记录用于存储某一个具体的数据
什么是SQL语言?
SQL是一们用于操作关系型数据库的通用的语言(使用SQL可以操作所有的关系型数据库)
使用SQL可以操作数据库、表、表记录
(1)创建数据库、删除数据库、修改数据库、查询数据库
(2)创建表、删除表、修改表、查询表
(3)新增表记录、删除表记录、修改表记录、查询表记录
使用SQL也可以操作存储过程/视图/索引等。
连接mysql服务器
通过命令行工具可以登录MySQL客户端,连接MySQL服务器,从而访问服务器中的数据
1、连接mysql服务器:
mysql -uroot -p密码
-u: 后面的root是用户名,这里使用的是超级管理员root;
-p:(小写的p) 后面的root是密码,这是在安装MySQL时就已经指定的密码;
2、连接mysql服务器并指定IP和端口:
mysql -uroot -proot -h127.0.0.1 -P3306
-h: 后面给出的127.0.0.1是服务器主机名或ip地址,可以省略的,默认连接本机;
-P:(大写的P) 后面的3306是连接端口,可以省略,默认连接3306端口;
3、退出客户端命令:quit或exit或 \q
4、FAQ:常见问题:
解决方法:复制mysql安装目录下的bin目录,将bin目录的路径添加到path环境变量中!!
数据库及表操作
创建、删除、查看数据库
提示: (1)SQL语句对大小写不敏感。推荐关键字使用大写,自定义的名称(库名,表名,列名等)使用小写。
SHOW DATABASES; -- 查看当前数据库服务器中的所有库
CREATE DATABASE mydb1; -- 创建mydb1库
(2)并且在自定义名称时,针对多个单词不要使用驼峰命名,而是使用下划线连接。(例如:tab_name,而不是 tabName )
– 01.查看mysql服务器中所有数据库
show databases;
– 02.进入某一数据库(进入数据库后,才能操作库中的表和表记录)
– 语法:USE 库名;
use mysql
– 查看已进入的库
SELECT DATABASE();
– 03.查看当前数据库中的所有表
-- 先进入某一个库,再查看当前库中的所有表
show tables;
– 04.删除mydb1库
– 语法:DROP DATABASE 库名;
drop database test;
– 05.重新创建mydb1库,指定编码为utf8
– 语法:CREATE DATABASE 库名 CHARSET 编码;
create database mydb1 charset utf8;
-- 如果存在mydb1,则先删除,再重建
– 如果不存在则创建mydb1;
create database if not exists mydb1 charset utf8;
– 06.查看建库时的语句(并验证数据库库使用的编码)
– 语法:SHOW CREATE DATABASE 库名;
show create database mydb1;
创建、删除、查看表
– 07.进入mydb1库,删除stu学生表(如果存在)
– 语法:DROP TABLE 表名;
use mydb1;
drop table if exists stu;
– 08.创建stu学生表(编号[数值类型]、姓名、性别、出生年月、考试成绩[浮点型]),建表的语法
CREATE TABLE 表名(
列名 数据类型,
列名 数据类型,
...
列名 数据类型
);
SQL语句:
---如果存在,则删除stu
drop table if exists stu;
---创建stu学生表
create table stu(
---auto_increment设置主键自增,前提是数值类型
id int primary key auto_increment, ---将id设置为主键
name varchar(16),
gender varchar(10),
birthday date,
score double
);
– 09.查看stu学生表结构
– 语法:desc 表名
desc stu;
新增、更新、删除表记录
– 10.往学生表(stu)中插入记录(数据)
– 语法:INSERT INTO 表名(列名1,列名2,列名3…) VALUES(值1,值2,值3…);
-- 如果是在cmd中执行插入记录的语句,先 set names gbk; 再插入记录!
set names gbk;
insert into stu(id,name,gender,birthday,score) values(001,'张三','男','1987-3-6',95.5);
insert into stu values(002,'小红','女','1981-1-2',85.5);
insert into stu values(003,'小刚','男','1981-1-2',80.5);
(1)当为所有列插入值时,可以省写列名,但值的个数和顺序必须和声明时列的个数和顺序保持一致!
(2)SQL语句中的值为字符串或日期时,值的两边要加上单引号(有的版本的数据库双引号也可以,但推荐使用单引号)。
(3)(针对cmd窗口)在插入数据之前,先设置编码:set names gbk;
– 11.查询stu表所有学生的信息
– 语法:SELECT 列名 | * FROM 表名
select * from stu;
– 12.修改stu表中所有学生的成绩,加10分特长分
– 修改语法: UPDATE 表名 SET 列=值,列=值,列=值…[WHERE子句];
update stu set score=score+10;
– 13.修改stu表中编号为1的学生成绩,将成绩改为83分。
where子句用于对记录进行筛选过滤,保留符合条件的记录,将不符合条件的记录剔除。
update stu set score=83 where id=1;
– 14.删除stu表中所有的记录
– 删除记录语法: DELETE FROM 表名 [where条件]
delete from stu;