认识数据库中的表

一、数据库

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 不能用于参与了索引视图的表。

三、数据库的查询

测试人员最主要用到的是数据查询,查询语句请参见之前的文章
《查询》

你可能感兴趣的:(认识数据库中的表)