數據庫

一、數據庫概述

  • 數據庫(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');
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章