MySql基礎知識總結


Mysql概述

MySql是一種關系型數據庫

連接到mysql數據庫:mysql -u root -p

什么是SQL:結構化的查詢語句

SQL分類:

  DDL:數據定義語言

   * create,alter,drop...

  DML:數據操縱語言

    * update,insert,delete

  DCL:數據控制語言

    * grant,if..

  DQL:數據查詢語言

    * select

數據庫增刪查改

創建數據庫:語法:create database 數據庫 [character 字符集 collate 校對規則]

查看數據庫:

  查看所有數據庫:show databases;

  查看某個數據庫:show create database 數據庫名;

修改數據庫:語法:alter database 數據庫名 character 字符集 collate 校對規則

刪除數據庫:語法:drop database 數據庫名;

切換數據庫:use 數據庫名;

查看當前使用數據庫:select database();

數據庫表操作

創建表語法:

  create table 表名 (

      字段名 類型(長度) 約束,

      字段名 類型(長度) 約束,

      字段名 類型(長度) 約束

  );

數據類型:

 Java類型:             MySQL:

  byte/short/int/long   tinyint/smallint/int/bigint

  String                char/varchar

                            * 區別?char是固定長度的字符串,varchar可變長度的字符串.

                            * char(8) 和 varchar(8)

                                * 如果插入一個字符串hello 插入到char 那么 插入hello   .插入到varchar中 插入hello

 float                  float

 double                 double

 boolean            bit

 Date                   date/time/datetime/timestamp

                        * datetime和timestamp都是既有日期又有時間的日期類型

                            * 區別? datetime需要使用外部傳入的日期.如果沒傳這個值就是Null. timestamp會使用系統當前的時間作為這個值的默認值.

 文本文件                Text

 二級制文件               BLOB

***** Oralce使用CLOB/BLOB

***** MYSQL中除了字符串類型需要設置長度其他的類型都有默認長度******

  • 約束:

單表約束:

* 主鍵約束:primary key (默認就是唯一非空的)

* 唯一約束:unique

* 非空約束:not null

 

  • 創建一個表:
  • ***** 創建表之前先選擇數據庫:use 某個數據庫;

create table employee(

    eid int primary key auto_increment,

    ename varchar(20) not null,

    email varchar(30) unique,

    birthday date,

    job varchar(20),

    resume text

);

【表的查看】

  • 查看數據庫中有哪些表:

* show tables;

  • 查看表結構:

* desc 表名;

【表的刪除】

  • 表的刪除:

 drop table 表名;

【表的修改】

  • 修改表添加列:

* alter table 表名 add 列名 類型(長度) 約束;

    * alter table employee add image varchar(50);

  • 修改表刪除列:

* alter table 表名 drop 列名;

    * alter table employee drop job;

  • 修改表的列的類型長度及約束:

* alter table 表名 modify 列名 類型(長度) 約束;

    * alter table employee modify image varchar(80) not null;

  • 修改表的列名

* alter table 表名 change 舊列名 新列名 類型(長度) 約束;

    * alter table employee change image eimage varchar(60);

  • 修改表名

* rename table 舊表名 to 新表名;

    * rename table employee to user;

  • 修改表的字符集:

* alter table 表名character set 字符集;

    * alter table user character set gbk;

*******使用SQL操作數據庫中的表的記錄(對表的記錄的CRUD的操作)******

【插入記錄】

  • 語法

* insert into 表名 (列名,列名,...) values (值1,值2,...);     ---插入指定列的值

* insert into 表名 values (值1,值2,...);                    ---插入所有列的值

 

  • 注意事項:

* 列名的個數與值的個數對應.

* 列的類型與值的類型對應.位置也要對應.

* 列的類型如果是字符串或者日期,寫值的時候使用單引號將值引起來.

* 插入的值的最大長度不能超過列的最大長度.

【修改記錄】

  • 語法:

* update 表 set 列名=值,列名=值 [where 條件];

  • 注意事項:

* 列名和值類型也要一致.

* 值不能超過列的最大長度.

* 值是字符串或日期,需要使用單引號.

  • 練習:

* 修改employee表中所有記錄的job為WORKER

    * update employee set job='WORKER';

* 修改employee表將name為aaa的郵箱改為aaa@163.com

    * update employee set email = 'aaa@163.com' where ename = 'aaa';

* 修改employee表將name為bbb的郵箱改為bbb@163.com同時修改jobHR

    * update employee set email = 'bbb@163.com' , job='HR' where ename='bbb';

【刪除記錄】

  • 語法:

* delete from 表 [where 條件];

  • 注意事項:

* 刪除表中的一行記錄,不能刪除某列值

* 如果沒有條件刪除表中的所有列.

  • 練習:

* 刪除id為8的記錄:

    * delete from employee where eid = 8;

* 刪除所有記錄:

    * delete from employee;

  • 刪除表中的所有記錄truncate table 表名  和 delete from 表  區別?

* 區別:

    * truncate table 刪除表的記錄:將整個表刪除掉,重新創建一個新的表.truncate屬於DDL.

    * delete from 刪除表的記錄:一條一條進行刪除. delete屬於DML

        * 事務管理 只能作用在DML語句上.如果再一個事務中使用delete刪除所有記錄,可以找回.

【基本查詢】

  • 查詢語句:

* select [distinct] *|列名 from 表 [where 條件];

【條件查詢】

  • where語句后面可以加:

條件的關鍵字:

= , > , >= , <, <= , <>

like中可以使用占位符: _ 和 %  :下划線匹配一個字符, %:可以匹配任意多個字符.

【排序查詢】

`order by 對數據進行排序.默認升序. (asc升序,desc降序)

【聚合函數】

`sum()   求和

`count()  統計

`max()  最大值

`min()  最小值

`avg() 平均數

【分組】

  group by

* 交叉連接

    * select * from A,B;   --- 獲得的是兩個表的笛卡爾積.

* 內連接: inner join -- inner 可以省略

    * 顯式內連接:select * from A inner join B on 條件;

    * 隱式內連接:select * from A,B where 條件;

* 外連接:outer join -- outer 可以省略

    * 左外連接:left outer join  -- select * from A left outer join B on 條件;

    * 右外連接:right outer join -- select * from A right outer join B on 條件;

多表查詢的子查詢

  • 一個SQL語句查詢的過程中需要依賴另一個查詢語句.

SELECT * FROM customer c,orders o WHERE c.cid = o.cid AND  c.cid IN (SELECT cid FROM orders WHERE addr LIKE '海淀%');

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM