认识数据库中的表

一、数据库

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

三、数据库的查询

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容