美文网首页
认识数据库中的表

认识数据库中的表

作者: TESTME | 来源:发表于2018-09-09 20:40 被阅读0次

    一、数据库

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

    三、数据库的查询

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

    相关文章

      网友评论

          本文标题:认识数据库中的表

          本文链接:https://www.haomeiwen.com/subject/bybdgftx.html