一、数据库
1.1.数据库是什么
数据库是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增删改查操作。
1.2.数据库管理系统是什么
数据库管理系统(DataBase Management System,简称DBMS):是一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据。
1.3.常见的数据库管理系统
Oracle :收费的大型数据库,Oracle公司的产品。Oracle收购SUN公司,收购MYSQL。
MYSQL :开源免费的数据库,小型的数据库.已经被Oracle收购了.MySQL6.x版本也开始收费。
DB2 :IBM公司的数据库产品,收费的。常应用在银行系统中.
SQLServer:MicroSoft 公司收费的中型的数据库。C#、.net等语言常使用。
SyBase :已经淡出历史舞台。提供了一个非常专业数据建模的工具PowerDesigner。
SQLite : 嵌入式的小型数据库,应用在手机端。
Java相关的数据库:MYSQL,Oracle.
1.4.数据库表
数据库中是以表为组织单位存储数据的。
表类似JAVA中的类,每个字段都有对应的数据类型。
JAVA | 表 |
---|---|
类 | 表 |
类属性 | 表字段 |
类对象 | 表记录 |
1.5 表数据
根据表字段所规定的数据类型,我们可以向其中插入一条条的数据,而表中的每条数据类似JAVA类的实例对象。表中的一行一行的信息我们称之为记录。
二、SQL语句
下面部分以SQL语句来详细介绍数据库表的相关知识。
2.1.什么是SQL语句?
结构化查询语言(Structured Query Language)简称SQL,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。创建数据库、创建数据表、向数据表中添加一条条数据信息均需要使用SQL语句。
2.2.SQL语句分类
数据定义语言:简称DDL(Data Definition Language),用来定义数据库对象:数据库,表,列等。关键字:create,alter,drop等
数据操作语言:简称DML(Data Manipulation Language),用来对数据库中表的记录进行更新。关键字:insert,delete,update等
数据查询语言:简称DQL(Data Query Language),用来查询数据库中表的记录。关键字:select,from,where等
数据控制语言:简称DCL(Data Control Language),用来定义数据库的访问权限和安全级别,及创建用户。
2.3.SQL通用语法
SQL语句可以单行或多行书写,以分号结尾;
可使用空格和缩进来增强语句的可读性;
MySQL数据库的SQL语句不区分大小写,建议使用大写,例如:SELECT * FROM user;
注释使用/**/
MySQL中的我们常使用的数据类型如下:
数据类型 | 意义 |
---|---|
int | 整形 |
double | 浮点型 |
varchar | 字符串型 |
date | 日期类型 |
2.4.SQL基本语句
2.4.1.创建数据库
CREATE DATABASE 数据库名;
CREATE DATABASE 数据库名 CHARACTER SET 编码类型;
创建数据库 数据库中数据的编码采用的是安装数据库时指定的默认编码 utf8
CREATE DATABASE china_book;
CREATE DATABASE china_book CHARACTER SET utf8; /*指定数据库中数据的编码*/
2.4.2.查看数据库
查看数据库MySQL服务器中的所有的数据库:show databases;
查看某个数据库的定义的信息:show create database 数据库名;
SHOW CREATE DATABASE china_book;
2.4.3.删除数据库
drop database 数据库名称;
DROP DATABASE china_book;
2.4.4.查看正在使用的数据库
SELECT DATABASE();
2.4.5.切换数据库
USE china_book;
2.5.表结构相关语句
2.5.1.创建表
语法:
create table 表名(
字段名 类型(长度) 约束,
字段名 类型(长度) 约束,
...
);
创建学生表
CREATE TABLE student (
s_id INT,
s_age INT,
S_name VARCHAR(50),
)
2.5.2.主键
主键是用于标识当前记录的字段。它的特点是非空,唯一。(在开发中一般情况下主键是不具备任何含义,只是用于标识当前记录)
主键格式:
a.在创建表时创建主键,在字段后面直接加上 PRIMARY KEY
CREATE TABLE student (
s_id INT PRIMARY KEY,
s_age INT,
s_name VARCHAR(50)
)
b.在创建表时创建主键,在表创建的最后来指定主键 PRIMARY KEY(主键的字段名)
CREATE TABLE student (
s_id INT,
s_age INT,
s_name VARCHAR(50),
PRIMARY KEY(s_id)
)
删除主键:ALTER TABLE 表名 DROP PRIMARY KEY
ALTER TABLE student DROP PRIMARY KEY;
主键自动增长:一般主键是自增长的字段,不需要指定。
实现添加自增长语句,主键字段后加auto_increment(只适用MySQL)
CREATE TABLE student (
s_id INT PRIMARY KEY auto_increment,
s_age INT,
s_name VARCHAR(50)
)
2.5.3.查看表
a.查看数据库中的所有表:SHOW TABLES;
b.查看表结构:DESC 表名; 如:DESC student;
2.5.4.删除表
DROP TABLE 表名
2.5.5.修改表结构格式
a.为表添加一个新的字段:ALERT TABLE 表名 add 列名 类型
ALERT TABLE studen ADD s_score INT
b.修改表的某个字段的类型和约束:ALERT TABLE 表名 MODIFY 列名 类型(长度) 约束;
ALERT TABLE student MODIFY s_score DOUBLE;
ALERT TABLE student s_id MODIFY NOT NULL /*不能为空*/
c.修改表的字段名:ALERT TABLE 表名 CHANGE 旧列名 新列名 类型(长度) 约束;
ALERT TABLE student CHANGE s_name student_name VARCHAR2(100)
d.删除表的某列:ALERT TABLE 表名 DROP 列名
ALERT TABLE student DROP s_score
e.修改表名:RENAME TABLE 表名 TO 新表名
RENAME TABLE student TO stu
f.修改表的字符集:ALERT TABLE 表名 CHARACTER SET 字符集;
ALERT TABLE stu CHARACTER SET gbk;
2.5.6.给表添加数据(插入记录)
a.向表中插入某些列(列举出需要插入的值)
INSERT INTO 表名 (列表1,列表2,列表3,...) VALUES (值1,值2,值3,...)
b.向表中插入所有列
INSERT INTO 表名 VALUES (值1,值2,值3,...)
插入数据的注意事项:
插入的数据应与字段的数据类型相同;
数据的大小应该在列的长度范围内;
在VALUES中列出的数据位置必须与被加入列的排列位置相对应;
除了数值类型外,其它的字段类型的值必须使用引号引起;
如果要插入空值,可以不写字段,或者插入 null;
对于自动增长的列在操作时,直接插入null值即可;
INSERT TABLE student(s_id,s_name) VALUES(100,'zhangsan')
INSERT TABLE student(s_id,s_name) VALUES(101,'lisi')
INSERT TABLE student(s_id,s_name) VALUES(102,'wanger')
INSERT TABLE student(s_id,s_name) VALUES(103,'mazi')
2.5.7.更新表数据
用来修改指定条件的数据,将满足条件的记录指定列修改为指定值
UPDATE 表名 SET 字段名=值,字段名=值;
UPDATE 表名 SET 字段名=值,字段名=值 WHERE 条件;
注意事项:
列名的类型与修改的值要一致;
修改值得时候不能超过最大长度;
值如果是字符串或者日期需要加''
将学生表里的分数全部改为100
UPDATE TABLE SET s_score=100;
将zhangsan的分数改成90
UPDATE TABLE SET s_score=90 WHERE s_name = 'zhangsan';
2.5.8.删除表数据
DELETE FROM 表名 [WHERE 条件];
TRUNCATE TABLE 表名
面试题:删除表中所有记录使用 DELETE FROM 表名; 还是用 TRUNCATE TABLE 表名?
答:
TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。
TRUNCATE TABLE 不能用于参与了索引视图的表。
三、数据库的查询
测试人员最主要用到的是数据查询,查询语句请参见之前的文章
《查询》