Mysql 学习1

Posted prozhu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql 学习1相关的知识,希望对你有一定的参考价值。

 

mysql学习

 

一、数据库

 

1 数据库概念(了解)

1.1 什么是数据库

数据库就是用来存储和管理数据的仓库!

数据库存储数据的优先:

  • 可存储大量数据;
  • 方便检索;
  • 保持数据的一致性、完整性;
  • 安全,可共享;
  • 通过组合分析,可产生新数据。

 

1.2 数据库的发展历程

  • 没有数据库,使用磁盘文件存储数据;
  • 层次结构模型数据库;
  • 网状结构模型数据库;
  • 关系结构模型数据库:使用二维表格来存储数据;
  • 关系-对象模型数据库;

 

  MySQL就是关系型数据库!

 

1.3 常见数据库

  • Oracle(神喻):甲骨文(最高!);
  • DB2:IBM;
  • SQL Server:微软;
  • Sybase:赛尔斯;
  • MySQL:甲骨文;

 

1.4 理解数据库

  • RDBMS = 管理员(manager)+仓库(database)
  • database = N个table
  • table:
    • 表结构:定义表的列名和列类型!
    • 表记录:一行一行的记录!

 

 

我们现在所说的数据库泛指"关系型数据库管理系统(RDBMS - Relational database management system)",即"数据库服务器"。

当我们安装了数据库服务器后,就可以在数据库服务器中创建数据库,每个数据库中还可以包含多张表。

数据库表就是一个多行多列的表格。在创建表时,需要指定表的列数,以及列名称,列类型等信息。而不用指定表格的行数,行数是没有上限的。下面是tab_student表的结构:

 

当把表格创建好了之后,就可以向表格中添加数据了。向表格添加数据是以行为单位的!下面是s_student表的记录:

 

s_id 

s_name 

s_age 

s_sex 

S_1001 

zhangSan 

23 

male 

S_1002 

liSi 

32 

female 

S_1003 

wangWu 

44 

male 

 

  大家要学会区分什么是表结构,什么是表记录。

 

1.5 应用程序与数据库

  应用程序使用数据库完成对数据的存储!

 

2 安装MySQL数据库

2.1 安装MySQL

  参考:MySQL安装图解.doc

 

2.2 MySQL目录结构

MySQL的数据存储目录为data,data目录通常在C:\\Documents and Settings\\All Users\\Application Data\\MySQL\\MySQL Server 5.1\\data位置。在data下的每个目录都代表一个数据库。

MySQL的安装目录下:

  • bin目录中都是可执行文件;
  • my.ini文件是MySQL的配置文件;

 

3 基本命令

3.1 启动和关闭mysql服务器

  • 启动:net start mysql;
  • 关闭:net stop mysql;

 

在启动mysql服务后,打开windows任务管理器,会有一个名为mysqld.exe的进程运行,所以mysqld.exe才是MySQL服务器程序。

 

3.2 客户端登录退出mysql

在启动MySQL服务器后,我们需要使用管理员用户登录MySQL服务器,然后来对服务器进行操作。登录MySQL需要使用MySQL的客户端程序:mysql.exe

  • 登录:mysql -u root -p 123 -h localhost;
    • -u:后面的root是用户名,这里使用的是超级管理员root;
    • -p:后面的123是密码,这是在安装MySQL时就已经指定的密码;
    • -h:后面给出的localhost是服务器主机名,它是可以省略的,例如:mysql -u root -p 123;
  • 退出:quit或exit;

 

在登录成功后,打开windows任务管理器,会有一个名为mysql.exe的进程运行,所以mysql.exe是客户端程序。

 

二、SQL语句

 

  1. SQL概述

1.1 什么是SQL

SQL(Structured Query Language)是"结构化查询语言",它是对关系型数据库的操作语言。它可以应用到所有关系型数据库中,例如:MySQL、Oracle、SQL Server等。SQ标准(ANSI/ISO)有:

  • SQL-92:1992年发布的SQL语言标准;
  • SQL:1999:1999年发布的SQL语言标签;
  • SQL:2003:2003年发布的SQL语言标签;

 

这些标准就与JDK的版本一样,在新的版本中总要有一些语法的变化。不同时期的数据库对不同标准做了实现。

虽然SQL可以用在所有关系型数据库中,但很多数据库还都有标准之后的一些语法,我们可以称之为"方言"。例如MySQL中的LIMIT语句就是MySQL独有的方言,其它数据库都不支持!当然,Oracle或SQL Server都有自己的方言。

 

1.2 语法要求

  • SQL语句可以单行或多行书写,以分号结尾;
  • 可以用空格和缩进来来增强语句的可读性;
  • 关键字不区别大小写,建议使用大写;

 

2 分类
  • DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
  • DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);
  • DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
  • DQL(Data Query Language):数据查询语言,用来查询记录(数据)。

 

3 DDL

3.1 基本操作

  • 查看所有数据库名称:SHOW DATABASES; 
  • 切换数据库:USE mydb1,切换到mydb1数据库;

3.2 操作数据库

  • 创建数据库:CREATE DATABASE [IF NOT EXISTS] mydb1;

创建数据库,例如:CREATE DATABASE mydb1,创建一个名为mydb1的数据库。如果这个数据已经存在,那么会报错。例如CREATE DATABASE IF NOT EXISTS mydb1,在名为mydb1的数据库不存在时创建该库,这样可以避免报错。

 

  • 删除数据库:DROP DATABASE [IF EXISTS] mydb1;

删除数据库,例如:DROP DATABASE mydb1,删除名为mydb1的数据库。如果这个数据库不存在,那么会报错。DROP DATABASE IF EXISTS mydb1,就算mydb1不存在,也不会的报错。

 

  • 修改数据库编码:ALTER DATABASE mydb1 CHARACTER SET utf8

修改数据库mydb1的编码为utf8。注意,在MySQL中所有的UTF-8编码都不能使用中间的"-",即UTF-8要书写为UTF8。

 

3.3 数据类型

MySQL与Java一样,也有数据类型。MySQL中数据类型主要应用在列上。

 

常用类型:

  • int:整型
  • double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
  • decimal:泛型型,在表单钱方面使用该类型,因为不会出现精度缺失问题;
  • char:固定长度字符串类型;
  • varchar:可变长度字符串类型;
  • text:字符串类型;
  • blob:字节类型;
  • date:日期类型,格式为:yyyy-MM-dd;
  • time:时间类型,格式为:hh:mm:ss
  • timestamp:时间戳类型:yyyy-MM-dd hh:mm:ss

 

3.4 操作表

  • 创建表:

    CREATE TABLE 表名(

    列名 列类型,

    列名 列类型,

    ......

    );

例如:

CREATE TABLE stu(

    sid     CHAR(6),

    sname    VARCHAR(20),

    age        INT,

    gender    VARCHAR(10)

);

 

再例如:

CREATE TABLE emp(

    eid        CHAR(6),

    ename    VARCHAR(50),

    age        INT,

    gender    VARCHAR(6),

    birthday    DATE,

    hiredate    DATE,

    salary    DECIMAL(7,2),

    resume    VARCHAR(1000)

);

 

  • 查看当前数据库中所有表名称:SHOW TABLES; 
  • 查看指定表的创建语句:SHOW CREATE TABLE emp,查看emp表的创建语句;
  • 查看表结构:DESC emp,查看emp表结构;
  • 删除表:DROP TABLE emp,删除emp表;
  • 修改表:
  1. 修改之添加列:给stu表添加classname列:

    ALTER TABLE stu ADD (classname varchar(100));

  2. 修改之修改列类型:修改stu表的gender列类型为CHAR(2):

    ALTER TABLE stu MODIFY gender CHAR(2);

  3. 修改之修改列名:修改stu表的gender列名为sex:

    ALTER TABLE stu change gender sex CHAR(2);

  4. 修改之删除列:删除stu表的classname列:

    ALTER TABLE stu DROP classname;

  5. 修改之修改表名称:修改stu表名称为student:

    ALTER TABLE stu RENAME TO student;

 

4 DML

4.1 插入数据

语法:

INSERT INTO 表名(列名1,列名2, …) VALUES(值1, 值2)

INSERT INTO stu(sid, sname,age,gender) VALUES(\'s_1001\', \'zhangSan\', 23, \'male\');

INSERT INTO stu(sid, sname) VALUES(\'s_1001\', \'zhangSan\');

 

语法:

INSERT INTO 表名 VALUES(值1,值2,…)

因为没有指定要插入的列,表示按创建表时列的顺序插入所有列的值:

INSERT INTO stu VALUES(\'s_1002\', \'liSi\', 32, \'female\');

 

  注意:所有字符串数据必须使用单引用

 

4.2 修改数据

语法:

UPDATE 表名 SET 列名1=值1, … 列名n=值n [WHERE 条件]

UPDATE stu SET sname=\'zhangSanSan\', age=\'32\', gender=\'female\' WHERE sid=\'s_1001\';

UPDATE stu SET sname=\'liSi\', age=\'20\' WHERE age>50 AND gender=\'male\';

UPDATE stu SET sname=\'wangWu\', age=\'30\' WHERE age>60 OR gender=\'female\';

UPDATE stu SET gender=\'female\' WHERE gender IS NULL

UPDATE stu SET age=age+1 WHERE sname=\'zhaoLiu\';

 

4.3 删除数据

语法:

DELETE FROM 表名 [WHERE 条件]

DELETE FROM stu WHERE sid=\'s_1001\'003B

DELETE FROM stu WHERE sname=\'chenQi\' OR age > 30;

DELETE FROM stu;

 

语法:

TRUNCATE TABLE 表名

TRUNCATE TABLE stu;

 

虽然TRUNCATE和DELETE都可以删除表的所有记录,但有原理不同。DELETE的效率没有TRUNCATE高!

TRUNCATE其实属性DDL语句,因为它是先DROP TABLE,再CREATE TABLE。而且TRUNCATE删除的记录是无法回滚的,但DELETE删除的记录是可以回滚的(回滚是事务的知识!)。

 

5 DCL

5.1 创建用户

说明:创建用户,必须指定用户名,同时得带上ip地址,表名该用户必须在指定的ip地址上才能进行登录数据库

语法:

CREATE USER 用户名@IP地址 IDENTIFIED BY \'密码\';

CREATE USER user1@localhost IDENTIFIED BY \'123\';(user1只能在localhost这个ip上登录)

CREATE USER user2@\'%\' IDENTIFIED BY \'123\';(这句表明user2用户可以在任何电脑上面都可以登录)

 

5.2 给用户授权

  语法:

GRANT 权限1, … , 权限n ON 数据库.* TO 用户名 [WITH GRANT OPTION]

GRANT CREATE,ALTER,DROP,INSERT,UPDATE,DELETE,SELECT ON mydb1.* TO user1@localhost;

GRANT ALL ON mydb1.* TO user2@localhost; 

 

5.3 撤销授权

  语法:

  REVOKE权限1, … , 权限n ON 数据库.* FORM 用户名

REVOKE CREATE,ALTER,DROP ON mydb1.* FROM user1@localhost;

 

5.4 查看用户权限

语法:

SHOW GRANTS FOR 用户名

SHOW GRANTS FOR user1@localhost;

 

5.5 删除用户

语法:

DROP USER 用户名

DROP USER user1@localhost;

 

5.6 修改用户密码

语法:

USE mysql;

UPDATE USER SET PASSWORD=PASSWORD(\'密码\') WHERE User=\'用户名\' and Host=\'IP\';

FLUSH PRIVILEGES;

UPDATE USER SET PASSWORD=PASSWORD(\'1234\') WHERE User=\'user2\' and Host=\'localhost\';

FLUSH PRIVILEGES;

 

三、数据查询语法(DQL)

  DQL就是数据查询语言,数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

语法:

SELECT selection_list /*要查询的列名称*/

FROM table_list /*要查询的表名称*/

WHERE condition /*行条件*/

GROUP BY grouping_columns /*对结果分组*/

HAVING condition /*分组后的行条件*/

ORDER BY sorting_columns /*对结果分组*/

LIMIT offset_start, row_count /*结果限定*/

 

创建名:

  • 学生表:stu

字段名称

字段类型

说明

sid

char(6) 

学生学号

sname

varchar(50) 

学生姓名

age 

int 

学生年龄

gender 

varchar(50) 

学生性别

 

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

字段名称

字段类型

说明

empno 

int

员工编号

ename 

varchar(50)

员工姓名

job 

varchar(50)

员工工作

mgr 

int

领导编号

hiredate 

date 

入职日期

sal 

decimal(7,2) 

月薪

comm 

decimal(7,2) 

奖金

deptno 

int

部分编号

 

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

字段名称

字段类型

说明

deptno 

int

部分编码

dname 

varchar(50)

部分名称

loc 

varchar(50)

部分所在地点

 

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 基础查询

1.1 查询所有列

SELECT * FROM stu;

 

1.2 查询指定列

SELECT sid, sname, age FROM stu;

 

2 条件查询

2.1 条件查询介绍

条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:

  • =、!=、<>、<、<=、>、>=;
  • BETWEEN…AND;
  • IN(set);
  • IS NULL;
  • AND;
  • OR;
  • NOT;

 

2.2 查询性别为女,并且年龄50的记录

  SELECT * FROM stu

WHERE gender=\'female\' AND ge<50;

 

2.3 查询学号为S_1001,或者姓名为liSi的记录

SELECT * FROM stu

WHERE sid =\'S_1001\' OR sname=\'liSi\';

 

2.4 查询学号为S_1001S_1002S_1003的记录

SELECT * FROM stu

WHERE sid IN (\'S_1001\',\'S_1002\',\'S_1003\');

 

2.5 查询学号不是S_1001S_1002S_1003的记录

SELECT * FROM tab_student

WHERE s_number NOT IN (\'S_1001\',\'S_1002\',\'S_1003\');

 

2.6 查询年龄为null的记录

SELECT * FROM stu

WHERE age IS NULL;

 

2.7 查询年龄在2040之间的学生记录

SELECT *

FROM stu

WHERE age>=20 AND age<=40;

或者

SELECT *

FROM stu

WHERE age BETWEEN 20 AND 40;

 

2.8 查询性别非男的学生记录

SELECT *

FROM stu

WHERE gender!=\'male\';

或者

SELECT *

FROM stu

WHERE gender<>\'male\';

或者

SELECT *

FROM stu

WHERE NOT gender=\'male\';

 

2.9 查询姓名不为null的学生记录

SELECT *

FROM stu

WHERE NOT sname IS NULL;

或者

SELECT *

FROM stu

WHERE sname IS NOT NULL;

 

3 模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE。

3.1 查询姓名由5个字母构成的学生记录

SELECT *

FROM stu

WHERE sname LIKE \'_____\';

模糊查询必须使用LIKE关键字。其中 "_"匹配任意一个字母,5个"_"表示5个任意字母。

 

3.2 查询姓名由5个字母构成,并且第5个字母为"i"的学生记录

SELECT *

FROM stu

WHERE sname LIKE \'____i\';

 

3.3 查询姓名以"z"开头的学生记录

SELECT *

FROM stu

WHERE sname LIKE \'z%\';

其中"%"匹配0~n个任何字母。

 

3.4 查询姓名中第2个字母为"i"的学生记录

SELECT *

FROM stu

WHERE sname LIKE \'_i%\';

 

3.5 查询姓名中包含"a"字母的学生记录

SELECT *

FROM stu

WHERE sname LIKE \'%a%\';

 

4 字段控制查询

4.1 去除重复记录

去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:

系统学习MySQL:1mysql系统库之复制信息表

思维导图学习---数据库相关基础思维导图

思维导图学习---数据库相关基础思维导图

思维导图学习---数据库相关基础思维导图

好课资源共享:1MySQL数据库高级工程师

mysql 学习笔记