数据库

一、数据库概述

  • 数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合。(文件系统)

  • 数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中的数据。

  • 数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。

  • 数据库:存储、维护和管理数据的集合。

二、数据库的安装与配置

三、sql概述

  • SQL:Structure Query Language。(结构化查询语言)
  • SQL被美国国家标准局(ANSI)确定为关系型数据库语言的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语言的国际标准。

  • 各数据库厂商都支持ISO的SQL标准。普通话

  • 各数据库厂商在标准的基础上做了自己的扩展。方言

四.Sql的分类

  • DDL**(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等; CREATE、 ALTER、DROP
  • DML***(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据); INSERT、 UPDATE、 DELETE
  • DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
  • DQL*****(Data Query Language):数据查询语言,用来查询记录(数据)。
4.1 DDL:操作数据库、表、列等
  • 使用的关键字:CREATE、 ALTER、 DROP

4.1.1操作数据库

  • 创建

    create database mydb1;
    Create database mydb2 character set gbk;
    Create database mydb3 character set gbk COLLATE gbk_chinese_ci;
  • 查询

    • 查看当前数据库服务器中的所有数据库

      show databases;
    • 查看前面创建的mydb2数据库的定义信息

      Show  create  database mydb2;
  • 修改

    • 查看服务器中的数据库,并把mydb2的字符集修改为utf8;

       alter database mydb2 character set utf8;
  • 删除

    drop database mydb3;
  • 其他:

    • 查看当前使用的数据库

      select database();
    • 切换数据库

      use mydb2;

4.1.2操作数据表

  • 语法:

    create table 表名(
        字段1 字段类型,
        字段2 字段类型,
        ...
        字段n 字段类型
    );
  • 常用数据类型:

        * int:整型
        * double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
        * char:固定长度字符串类型; char(10)  'abc       '
        * varchar:可变长度字符串类型;varchar(10) 'abc'
        * text:字符串类型;
        * blob:字节类型;
        * date:日期类型,格式为:yyyy-MM-dd;
        * time:时间类型,格式为:hh:mm:ss
        * timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss  会自动赋值
        * datetime:日期时间类型 yyyy-MM-dd hh:mm:ss
    
  • 当前数据库中的所有表

    SHOW TABLES;
  • 查看表的字段信息

    DESC employee;
  • 在上面员工表的基本上增加一个image列(增加列)

    ALTER TABLE employee ADD image blob;
  • 修改job列,使其长度为60(修改列属性)

    ALTER TABLE employee MODIFY job varchar(60);
  • 删除image列,一次只能删一列(删除列)

    ALTER TABLE employee DROP image;
  • 表名改为user(修改表名)

    RENAME TABLE employee TO user;
  • 查看表格的创建细节

    SHOW CREATE TABLE user;
  • 修改表的字符集为gbk。

    ALTER TABLE user CHARACTER SET gbk;
  • 列名name修改为username

    ALTER TABLE user CHANGE name username varchar(100);
  • 删除表

    DROP TABLE user ;
4.2 DML操作(重要)
  • DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。
  • INSERT 、UPDATE、 DELETE

  • 小知识:
    在mysql中,字符串类型和日期类型都要用单引号括起来。’tom’ ‘2015-09-04’

  • 空值:null

4.2.1插入操作:INSERT:

  • 语法: INSERT INTO 表名(列名1,列名2 …)VALUES(列值1,列值2…);
  • 注意:列名与列值的类型、个数、顺序要一一对应。
    • 可以把列名当做java中的形参,把列值当做实参。
    • 值不要超出列定义的长度。
    • 如果插入空值,请使用null
    • 插入的日期和字符一样,都使用引号括起来。
  • 练习 :
//创建表
create table emp(
    id int,
    name varchar(100),
    gender varchar(10),
    birthday date,
    salary float(10,2),
    entry_date date,
    resume text
);

//插入数据
INSERT INTO emp VALUES
(4,'zs','m','2015-09-01',10000,'2015-09-01',NULL),
(5,'li','m','2015-09-01',10000,'2015-09-01',NULL),
(6,'ww','m','2015-09-01',10000,'2015-09-01',NULL);

4.2.2 修改操作 UPDATE:

  • 语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值
  • 练习:

    • 将所有员工薪水修改为5000元。

      UPDATE emp SET salary=5000 
    • 将姓名为’zs’的员工薪水修改为3000元。

      UPDATE emp SET salary=3000 WHERE name=’ zs;
    • 将姓名为’li’的员工薪水修改为4000元,性别修改为女。

      update emp set salary = 4000,gender = 'w' where name='li';
    • 将ww的薪水在原有基础上增加1000元。
    update emp set salary = salary + 1000 where name = 'ww';    

4.2.3 删除操作 DELETE:

  • 语法 : DELETE FROM 表名 【WHERE 列名=值】
  • 练习 :

    • 删除表中名称为’zs’的记录。
      DELETE FROM emp WHERE name=‘zs’;
    • 删除表中所有记录。
      DELETE FROM emp;
    • 使用truncate删除表中记录。
      TRUNCATE TABLE emp;
  • DELETE和TRUNCATE 的区别:

    • DELETE: 删除表中的数据,表结构还在;删除后的数据可以找回
    • TRUNCATE :删除是把表直接DROP掉,然后再创建一个同样的新表。删除的数据不能找回。执行速度比DELETE快。
4.3 DQL操作
  • DQL数据查询语言 (重要)

    • 数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。
    • 查询返回的结果集是一张虚拟表。
  • 查询关键字:SELECT

    • 语法: SELECT 列名 FROM表名
      【WHERE –> GROUP BY –>HAVING–> ORDER BY】
  • 语法:
    • SELECT selection_list /要查询的列名称/
    • FROM table_list /要查询的表名称/
    • WHERE condition /行条件/
    • GROUP BY grouping_columns /对结果分组/
    • HAVING condition /分组后的行条件/
    • ORDER BY sorting_columns /对结果分组/
    • LIMIT offset_start, row_count /结果限定/

这里写图片描述
这里写图片描述
这里写图片描述

//创建stu表
CREATE TABLE stu (
    sid CHAR(6),
    sname       VARCHAR(50),
    age     INT,
    gender  VARCHAR(50)
);
INSERT INTO stu VALUES('S_1001', 'liuYi', 35, 'male');
INSERT INTO stu VALUES('S_1002', 'chenEr', 15, 'female');
INSERT INTO stu VALUES('S_1003', 'zhangSan', 95, 'male');
INSERT INTO stu VALUES('S_1004', 'liSi', 65, 'female');
INSERT INTO stu VALUES('S_1005', 'wangWu', 55, 'male');
INSERT INTO stu VALUES('S_1006', 'zhaoLiu', 75, 'female');
INSERT INTO stu VALUES('S_1007', 'sunQi', 25, 'male');
INSERT INTO stu VALUES('S_1008', 'zhouBa', 45, 'female');
INSERT INTO stu VALUES('S_1009', 'wuJiu', 85, 'male');
INSERT INTO stu VALUES('S_1010', 'zhengShi', 5, 'female');
INSERT INTO stu VALUES('S_1011', 'xxx', NULL, NULL);

//创建emp表
CREATE TABLE emp(
    empno       INT,
    ename       VARCHAR(50),
    job     VARCHAR(50),
    mgr     INT,
    hiredate    DATE,
    sal     DECIMAL(7,2),
    comm        decimal(7,2),
    deptno      INT
) ;
INSERT INTO emp values(7369,'SMITH','CLERK',7902,'1980-12-17',800,NULL,20);
INSERT INTO emp values(7499,'ALLEN','SALESMAN',7698,'1981-02-20',1600,300,30);
INSERT INTO emp values(7521,'WARD','SALESMAN',7698,'1981-02-22',1250,500,30);
INSERT INTO emp values(7566,'JONES','MANAGER',7839,'1981-04-02',2975,NULL,20);
INSERT INTO emp values(7654,'MARTIN','SALESMAN',7698,'1981-09-28',1250,1400,30);
INSERT INTO emp values(7698,'BLAKE','MANAGER',7839,'1981-05-01',2850,NULL,30);
INSERT INTO emp values(7782,'CLARK','MANAGER',7839,'1981-06-09',2450,NULL,10);
INSERT INTO emp values(7788,'SCOTT','ANALYST',7566,'1987-04-19',3000,NULL,20);
INSERT INTO emp values(7839,'KING','PRESIDENT',NULL,'1981-11-17',5000,NULL,10);
INSERT INTO emp values(7844,'TURNER','SALESMAN',7698,'1981-09-08',1500,0,30);
INSERT INTO emp values(7876,'ADAMS','CLERK',7788,'1987-05-23',1100,NULL,20);
INSERT INTO emp values(7900,'JAMES','CLERK',7698,'1981-12-03',950,NULL,30);
INSERT INTO emp values(7902,'FORD','ANALYST',7566,'1981-12-03',3000,NULL,20);
INSERT INTO emp values(7934,'MILLER','CLERK',7782,'1982-01-23',1300,NULL,10);

//创建dept表
CREATE TABLE dept(
    deptno      INT,
    dname       varchar(14),
    loc     varchar(13)
);
INSERT INTO dept values(10, 'ACCOUNTING', 'NEW YORK');
INSERT INTO dept values(20, 'RESEARCH', 'DALLAS');
INSERT INTO dept values(30, 'SALES', 'CHICAGO');
INSERT INTO dept values(40, 'OPERATIONS', 'BOSTON');
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值