Java SQl数据库

1.数据库

1.1.什么是数据库

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,简而言之就是存储数据的仓库。

1.2.数据库的分类:

层次式数据库, 网络式数据库,关系型数据库

数据库可以按照一定的数据结构存储管理大量的数据及数据与数据之间的关系,它本质上是一种信息管理系统。数据库根据存储采用的数据结构的不同可以分为许多种,其中常见的有层次式数据库、网络式数据库、关系型数据库。其中关系型数据库占据着市场的主流

1.4.常见的关系型数据库:

SqlServer

Oracle

MySql

DB2

...

1.5.MySql介绍

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于 Oracle旗下产品。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL所使用的SQL 语言是用于访问数据库的最常用标准化语言。MySQL的特点是体积小、速度快、总体拥有成本低,并且开源。

1.6.MySQL相关命令

登录mysql客户端命令:mysql -uroot -p123 -h localhost

-u:后面的root是用户名,这里使用的是超级管理员root

-p:后面的123是密码,这是在安装MySQL时就已经指定的密码;

-h:后面给出的localhost是服务器主机名,它是可以省略的,例如:mysql -u root -p 123 

退出客户端命令:quitexit 

扩展: 通过命令启动、停止、删除服务(C:\Windows\System32下以管理员运行cmd.exe)

启动:net start 服务名称

关闭:net stop 服务名称

删除:sc delete 服务名称

(如果服务名中间有空格,就需要前后加引号)

问题:

没有配置mysqlbin目录到path环境变量中!!!!

1.7.MySql常见的概念

数据库服务器: 安装的mysql软件就是mysql服务器。

数据库: 是数据库表的集合,数据库服务器中可以创建多个数据库。

表: 类似于一个excel表格,用于存储数据。

表记录: 即表中的一行数据。

2.SQL语言

2.1.SQL概述

SQL,指结构化查询语言,全称是 Structured Query Language

SQL是操作关系型数据库通用的语言

SQL是非过程性语言

SQL是一个标准,各大数据库厂商都根据该标准提供了实现。

数据库厂商为了增强数据库的功能,添加了一些非标准的SQL,称之为数据库的“方言”。

2.2.SQL能干什么?

SQL 可以创建、修改、删除数据库,包括查询服务器中所有数据库。

SQL 可以创建、修改、删除数据库表,包括查询数据库中所有的表

SQL 可以在数据库中插入新的记录,或修改、删除已有的记录

SQL可以查询数据库中的数据

……

3.利用sql语句来操作数据库

3.1.创建数据库

语法:

CREATE  DATABASE  [IF NOT EXISTS]  db_name  [CHARACTER SET charset_name] [COLLATE collation_name]

其中charset_name是为数据库指定的默认字符集

Collate是为数据库指定的默认校对规则

(校对规则是在字符集内用于比较字符的一套规则,可以控制select查询时where条件大小写是否敏感的规则。)

练习:

~创建一个名称为mydb1的数据库。

create database mydb1;

~创建一个使用gbk字符集的mydb2数据库。

create database mydb2 character set gbk;

3.2.查看数据库

语法:

显示所有数据库:

SHOW DATABASES

显示数据库创建语句:

SHOW CREATE DATABASE db_name

练习:

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

SHOW DATABASES;

~查看前面创建的mydb2数据库的定义信息

SHOW CREATE DATABASE mydb2; 

3.3.修改数据库

注意: 数据库一旦创建成功, 其名字无法修改!

语法:

ALTER DATABASE db_name  [CHARACTER SET charset_name] [COLLATE collation_name]

练习:

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

alter database mydb2 character set utf8; 

3.4.删除数据库

语法: DROP DATABASE  [IF EXISTS]  db_name

练习: 

~删除前面创建的mydb2数据库

DROP DATABASE mydb2; 

3.5.选择数据库

语法:

选择数据库: use db_name;

查询当前选择的数据: select database();

( 没有退出数据库的命令,如果想退出当前数据库进入另一个数据,直接use切换到另一个数据库就可以了)

4.利用sql语句来操作数据库表

4.1.MySQL中常见的数据类型

4.1.1.字符串类型

char(n) 定长字符串   

n的最大值为255,表示存储255个字符

例如:stuid char(10)

一般用于长度固定的字符串,比如手机号、身份证号等,效率高

 

varchar(n) 不定长字符串

n的最大值为 65535个字节(5.0以后的版本)

例如:username varchar(50)

一般用于长度不固定的字符串,比如用户名、昵称等,节省空间

4.1.2.数值类型

TINYINT:占用1个字节,相对于java中的byte

SMALLINT:占用2个字节,相对于java中的short

INT占用4个字节,相对于java中的int

BIGINT占用8个字节,相对于java中的long

FLOAT4字节单精度浮点类型,相对于java中的float

DOUBLE8字节双精度浮点类型,相对于java中的double

4.1.3.大数据类型

BLOB

大二进制类型,可以存入二进制类型的数据,通过这个字段,可以将图片、音频、视频等数据以二进制的形式存入数据库。最大为4GB

TEXT

大文本,被声明为这种类型的字段,可以保存大量的字符数据,最大为4GB

注意:text属于mysql的方言,在其他数据库中为clob类型

4.1.4.日期类型

DATE:日期 2015-11-05

TIME:时间 格式 'HH:MM:SS' 19:19:19

DATETIME:日期时间 2015-11-05 19:19:19 年份范围:1000~9999

TIMESTAMP:时间戳 2015-11-05 19:19:19 年份范围:1970~2037 

4.1.5.逻辑型

BIT型字段只能取两个值:01

4.2.字段的约束

主键约束:保证所约束列中的值必须唯一且不能为空。

添加主键约束(创建表时)col_name datatype primary key

(表已存在)Alter table tabname add primary key(col_name)

设置主键自动增长:col_name datatype primary key auto_increment

唯一约束: unique 保证所约束列的值必须唯一,即不能重复。

非空约束: not null 保证所约束列的值不能为空

外键约束:(放到后面单讲)

4.3.新增表

语法:

CREATE TABLE table_name (

field1  datatype,

field2  datatype,

field3  datatype

)[character set 字符集] [collate校对规则]  

field:指定列名 datatype:指定列类型

注意:

创建表时,要根据需保存的数据创建相应的列,并根据数据的类型定义相应的列类型。

创建表时,一般不需要指定字符集编码和校对规则,和数据库保持一致即可。

练习:

创建employee表,表中字段信息如下:

建表语句1

create table employee(
id int,
name varchar(50), 
gender char(1),
birthday date,
entry_date date,
job varchar(50),
salary double,
resume text
);

表语句2

create table employee(
id int primary key auto_increment,
name varchar(50) unique, 
gender bit not null,
birthday date,
entry_date date,
job varchar(50),
salary double,
resume text
);

4.4.查看表

语法:

查看表结构:

desc tabName

查看当前所有表:

show tables

查看当前数据库表建表语句

show create table tabName;

4.5.修改表

语法:

增加列:

ALTER TABLE tabname ADD col_name datatype [DEFAULT expr][,ADD col_name datatype...];

修改列:

ALTER TABLE tabname MODIFY (col_name datatype [DEFAULT expr][,MODIFY col_name datatype]...); 

删除列:

ALTER TABLE tabname DROP [COLUMN] col_name;

修改表名:

ALTER TABLE old_tabname RENAME TO new_tabname;

RENAME TABLE old_tabname TO new_tabname;

修改列名称:

ALTER TABLE tabname CHANGE [COLUMN] old_col_name new_col_name datatype;

修改列的顺序:

ALTER TABLE tabname MODIFY col_name1 datatype AFTER col_name2;

修改表的字符集:

ALTER TABLE tabname CHARACTER SET character_name; 

练习:

~在上面员工表的基础上增加一个image列。

alter table employee add image blob; 

~修改job列,使其长度为60

alter table employee modify job varchar(60); 

~删除gender列。

alter table employee drop gender; 

~表名改为user

alter table employee rename to user;

rename table user to employee; 

~列名name修改为username

alter table employee change name username varchar(100);

~image插入到id列的后面

alter table employee modify image blob after  id; 

~修改表的字符集为GBK

alter table employee character set gbk; 

4.6.删除表

语法: DROP TABLE tabname; 

练习: ~删除employee

drop table user;

5.利用sql语句来操作数据库表记录

5.1.INSERT

语法:

INSERT INTO tabname [(column [, column...])] VALUES (value [, value...]);

注意:

* 插入的数据应与字段的数据类型相同

例如: name列对应的值为字符串,插入的数据类型也应该是字符串类型!

* 数据的大小应在列的规定范围内

例如: name列字符长度为10,那么插入的数据长度不能超过10!

* values中列出的数据位置必须与被对应列的排列位置相对应

* 字符串和日期格式的数据要用单引号引起来

例如: '张飞', '2017-6-1'

* 如果要插入所有字段可以省写列列表,直接按表中字段声明的顺序写值列表

练习:

~向员工表中插入三条数据

insert into employee (id, name, gender, birthday, entry_date, job, salary, resume) values(null, '刘备', '', '1876-1-1', '1902-1-1', 'CEO', 100000, '很牛!!!');

insert into employee values(null, '张飞', '' , '1879-1-1', '1905-1-1', '大数据工程师', 20000, '还行吧!');

insert into employee values(null, '小乔', '' , '1882-1-1', '1906-1-1', '程序员鼓励师', 40000, '美女!'); 

** MySQL中插入中文数据,或查询中文数据时的乱码问题:

 

**乱码问题:客户端发送的数据是GBK的,而服务器使用的utf-8的编码来处理客户端发来的数据,两端使用的编码不一致导致乱码。

**解决方法1:在客户端可以通过set names gbk; 通知服务器使用指定码表来处理客户端发送的数据。这种方式只对当前cmd命令窗口有效,每次新开的窗口都要设置一次。

**解决方式2:可以通过修改MySQL安装目录下的my.ini文件(57)中的配置,来指定服务器端使用的码表。这种方式一劳永逸。(注意:配置完成后需要重启服务器!!);

查询数据库中编码: show variables like 'char%';

5.2.UPDATE

语法:

UPDATE tab_name SET col_name1=expr1 [, col_name2=expr2 ...] [WHERE where_definition]   

UPDATE语法可以用新值更新原有表行中的各列。

SET子句指示要修改哪些列和要给予哪些值。

WHERE子句指定应更新哪些行。如没有WHERE子句,则更新所有的行。

练习:

~将所有员工薪水修改为30000元。

update employee set salary=30000;

~将姓名为’貂蝉’的员工薪水修改为11000元。

update employee set salary=11000 where name='貂蝉';

~将张飞的薪水在原有基础上增加1000元。

update employee set salary=salary+1000 where name=’张飞’;

注意:mysql不支持+=符号 

5.3.DELETE

语法:

DELETE FROM tab_name [WHERE where_definition]

where用来筛选要删除的记录,如果不使用where子句,将删除表中所有数据。

delete语句不能删除某一列的值

delete语句仅删除记录,不删除表本身。如要删除表,使用drop table语句。

练习:

~删除表中名称为’张飞’的记录。

delete from employee where name='张飞';

~删除表中所有记录。

delete from employee

5.4.SELECT

5.4.1.基本的查询

语法:

SELECT [DISTINCT] * | {column1, column2. column3..} FROM table_name;

select 指定查询哪些列的数据。

column指定列名。

* 号代表查询所有列。

from指定查询哪张表。

DISTINCT可选,指显示结果时,是否剔除重复数据

 

练习:

执行下面的SQL,创建exam表并插入数据

create table exam(

id int primary key auto_increment,

name varchar(20) not null,

chinese double,

math double,

english double

);

 

insert into exam values(null,'关羽',85,76,70);

insert into exam values(null,'张飞',70,75,70);

insert into exam values(null,'赵云',90,65,95);

insert into exam values(null,'张三丰',85,79,null);

 

~查询表中所有学生的信息。

select * from exam;

~查询表中所有学生的姓名和对应的语文成绩。

select name, chinese from exam;

~过滤表中重复数据。

select distinct chinese from exam;

 

~在所有学生分数上加10分特长分显示。

select name,chinese+10,math+10,english+10 from exam;

或者

select name,chinese+10 as 语文, math+10 as 数学, english+10英语 from exam;###通过as关键词指定别名, as可以省略不写!

或者

select name,chinese+10 '语文', math+10数学, english+10英语 from exam;###通过as关键词指定别名, as可以省略不写!

 

~统计每个学生的总分。(ifnull(colname, 0))

select name, chinese+math+english 总分 from exam;

 

select name, chinese+math+ifnull(english, 0) 总分 from exam;

 

5.4.2.使用where子句的查询

语法:

SELECT * | 列名 FROM tablename [WHERE where_definition]

 

练习:

~查询姓名为关羽的学生成绩

select * from exam where name='关羽';

~查询英语成绩大于90分的同学

select * from exam where english>90;

~查询总分大于230分的所有同学

select name, chinese+math+ifnull(english, 0) 总分 from exam where chinese+math+ifnull(english, 0)>230;###where子句中不能使用列别名!!!

~查询语文分数在 80~100之间的同学。

select * from exam where chinese>80 and chinese <100;

或者

select * from exam where chinese between 80 and 100;#包括80100

 

~查询数学分数为75,76,77的同学。再查询分数不在这个范围内的同学

select * from exam where math=75 or math=76 or math=77;

select * from exam where !(math=75 or math=76 or math=77);

select * from exam where not(math=75 or math=76 or math=77);

或者

select * from exam where math in(75, 76, 77);

select * from exam where math not in(75, 76, 77);

~查询数学分>70,语文分>80的同学。

select * from exam where math>70 and chinese>80;

~查询所有姓张的学生成绩。

like: 模糊查询  

百分号(%:匹配0个或者多个字符。 下划线(_:匹配一个字符


select * from exam where name like '%';

select * from exam where name like '_';

select * from exam where name like '%%';

5.4.3.排序查询

语法:

SELECT column1, column2, column3.. FROM tablename order by column asc|desc;

Order by 指定排序的列,排序的列即可是表中的列名,也可以是select语句后指定的列名。

Asc 升序(默认)Desc降序

ORDER BY 子句应位于SELECT语句的结尾。

 

练习:

~对数学成绩排序后输出。

select math from exam order by math;

~对总分排序按从高到低的顺序输出

select name, chinese+math+ifnull(english, 0) 总分 from exam order by 总分desc;

 

~对姓张的学生总分排序输出

select name, chinese+math+ifnull(english, 0) 总分 from exam where name like '%' order by总分;

 

5.4.4.聚合函数

语法:

求符合条件的记录中指定列的记录数

select count(列名)from tablename [WHERE where_definition]

求符合条件的记录中指定列的和值

select sum(列名)from tablename [WHERE where_definition]

求符合条件的记录中指定列的平均值

select avg(列名)from tablename [WHERE where_definition]

求符合条件的记录中指定列的最大值

select max(列名)from tablename [WHERE where_definition]

求符合条件的记录中指定列的最小值

select min(列名)from tablename [WHERE where_definition]

 

练习:

~统计一个班级共有多少学生?

select count(*) from exam;

 

~统计数学成绩大于75的学生有多少个?

select count(*) from exam where math>75;

 

~统计总分大于230的人数有多少?

select count(*) from exam where chinese+math+ifnull(english, 0)>230;

 

~统计一个班级数学总成绩?

select sum(math) 数学总成绩from exam;

 

~统计一个班级语文、英语、数学三科成绩的总和

select sum(math)+sum(chinese)+sum(ifnull(english, 0))总成绩 from exam;

或者

select sum(chinese+math+ifnull(english, 0)) from exam;

~统计一个班级英语成绩平均分

select avg(english) from exam;

~求一个班级总分平均分?

select avg(chinese+math+ifnull(english, 0)) from exam;

 

~求班级总分最高分和最低分

select max(chinese+math+ifnull(english, 0)) from exam;

select min(chinese+math+ifnull(english, 0)) from exam;

 

5.4.5.分组查询

语法:

SELECT column1, column2. column3.. FROM tablename group by column having ...

 

练习:

执行下面的SQL,创建orders表并插入数据

create table orders(

id int,

product varchar(20),

price float

);

 

insert into orders(id,product,price) values(1,'小米手机',900);

insert into orders(id,product,price) values(2,'奥妙洗衣液',60);

insert into orders(id,product,price) values(3,'乐视TV',90);

insert into orders(id,product,price) values(4,'联想键盘',80);

insert into orders(id,product,price) values(5,'奥妙洗衣液',60);

insert into orders(id,product,price) values(6,'小米手机',900);

 

~对订单表中商品归类后,显示每一类商品的总价

select * from orders group by product;

select count(*) from orders group by product;

select sum(price) from orders group by product;

 

~查询购买了几类商品,并且每类总价大于100的商品

select product,sum(price) 总价 from orders group by product having sum(price)>100;

~查询单价小于100而总价大于100的商品的名称.

select * from orders where price<100 group by product having sum(price) > 100;

 

**wherehaving的区别?

* where子句和having子句都可以进行过滤,但是使用场景有所不同:

* where子句对分组之前的数据进行过滤,不能使用聚合函数和列别名

* having子句对分组之后的数据进行过滤,可以使用聚合函数和别名

* 使用where子句的地方一般都可以用having替代,但是使用having的地方一般不能用where替代

6.数据库的备份与恢复

6.1.备份数据库,cmd窗口中:

备份命令: mysqldump -u用户名-p 数据库名字> 数据文件的位置

例如: mysqldump -uroot -p mydb1 > e:\1.sql

6.2.恢复数据到数据库

方式一: cmd:

命令: mysql -u用户名-p 数据库名字< 数据文件的位置

例如: mysql -uroot -p mydb3 < e:\1.sql

方式二: mysql客户端中

命令: SOURCE 数据文件的位置

例如: source e:/1.sql

7.外键约束

外键:唯一标识其他表中的一条记录,用来通知数据库两张表字段之间的对应关系, 并让数据库帮我们维护这样关系的键就叫做外键

外键作用: 确保数据库数据的完整性和一致性

添加外键: 例如:foreign key(dept_id) references dept(id)

案例:

create table dept(

id int primary key auto_increment,

name varchar(20)

);

insert into dept values(null, '财务部');

insert into dept values(null, '人事部');

insert into dept values(null, '科技部');

insert into dept values(null, '销售部');

 

create table emp(

id int primary key auto_increment,

name varchar(20),

dept_id int,

foreign key(dept_id) references dept(id)

);

insert into emp values(null, '张三', 1);

insert into emp values(null, '李四', 2);

insert into emp values(null, '老王', 3);

insert into emp values(null, '赵四', 4);

insert into emp values(null, '刘能', 4);

要求:

1)执行上面的SQL语句,创建两张表(deptemp),在创建时先不指定dept_id为外键,尝试删除部门表中的某一个部门。

2)将deptemp表删除重建,在创建时指定dept_id为外键,再次尝试删除部门表中的某一个部门。

8.多表设计(参见多表设计图)

11 - *(一对多):在多的一方添加列保存一的一方的主键来作为外键,来保存两张表之间的关系

21 - 1(一对一):在任意一方添加列保存另一方的主键作为外键,来保存两张表之间的关系

3* - *(多对多):在一张第三方的表中分别保存两张表的主键作为外键,来保存两张表之间的关系,可以把多对多的关系拆分成两个一对多的关系来理解

 

9.多表查询

案例:

create table dept(

id int primary key auto_increment,

name varchar(20)

);

 

insert into dept values(null, '财务部');

insert into dept values(null, '人事部');

insert into dept values(null, '科技部');

insert into dept values(null, '销售部');

 

create table emp(

id int primary key auto_increment,

name varchar(20),

dept_id int

);

 

insert into emp values(null, '张三', 1);

insert into emp values(null, '李四', 2);

insert into emp values(null, '老王', 3);

insert into emp values(null, '刘能', 5);

 

需求1:查询出部门表和员工表,同时列出部门信息和员工信息。

select * from dept,emp;(笛卡尔积查询)

 

select * from dept, emp where emp.dept_id=dept.id;

或者

select * from dept inner join emp on emp.dept_id=dept.id;

需求2:查询出部门信息和部门所对应的员工信息,同时列出那些没有员工的部门

select * from dept left join emp on emp.dept_id=dept.id;

需求3:查询出部门信息和部门所对应的员工信息,同时列出那些没有部门的员工

select * from dept right join emp on emp.dept_id=dept.id;

需求4:查询出部门信息和部门所对应的员工信息,同时列出没有员工的部门和那些没有部门的员工

select * from dept full join emp on emp.dept_id=dept.id;###mysql不支持

 

笛卡尔积查询:

两张表相乘得出来的结果。如果左边表有m条记录,右边有n条记录,则查询出来的结果就是m*n条。这些查询结果中包含大量错误的结果,通常不会使用这种查询。

 

内连接查询:查询出左边表(dept)有且右边表(emp)也有的记录。

select * from emp inner join dept on dept.id=dept_id;

 

左外连接查询:在内连接查询的基础上,加上左边表有而右边表没有的记录

**查询出部门所对应的员工信息,同时列出那些没有员工的部门

select * from dept left join emp on dept.id=dept_id;

 

右外连接查询:在内连接查询的基础上,加上右边表有而左边表没有的记录。

**查询出部门所对应的员工信息,同时列出那些没有部门的员工

select * from dept right join emp on dept.id=dept_id;

 

全外连接查询:在内连接查询的基础上,加上左边表有而右边表没有的记录 右边表有而左边表没有的记录。

**查询出部门所对应的员工信息,同时列出那些没有员工的部门及些没有部门的员工

select * from dept full join emp on dept.id=dept_id;###mysql不支持全外连接查询

 

使用union模拟全外连接查询:

select * from dept left join emp on dept.id=dept_id

union

select * from dept right join emp on dept.id=dept_id;


mysql与oraclede的异同?

相同点:1.都是关系型数据库管理系统 2.都是目前比较流行的数据库

不同点:1.单引号的处理 mysql里可以用双引号包起字符串,oracle里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现 的一个单引号替换成两个单引号。

            2.自动增长的数据类型处理mysql是一个自动增长的数据类型,插入数据的时候,不需要管理,它自己会自动增长,oracle不支持自动增长的数据类型,通过建立一个自动增长的序列号来完成自动增长。

              3.sql语句的扩展和灵活性
              mysql对sql语句有很多非常实用而方便的扩展,比如limit功能,insert可以一次插入多行数据,select某些管理数据可以不加from。
              oracle在这方面感觉更加稳重传统一些。

              4.事物提交方式
              oracle默认不自动提交,需要用户手动提交。
              mysql默认是自动提交。不支持事物。
              mysql默认自动提交,也就是你提交一个query,他就直接执行,我们可以通过
              set autocommit=0 禁止自动提交
              set autocommit=1 开启自动提交


知识扩展:B树、B+树、B*树、平衡二叉树  https://zhuanlan.zhihu.com/p/27700617
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值