* 课程回顾:
* 完成注册和登陆的功能。
* 准备的工作
* 技术、开源jar包
* 开发的功能使用MVC模式
* C:控制层(接收请求和从客户端发送过来的参数)
* 接收参数(request对象)
* 为了操作方便(封装数据,内省,BeanUtils开源的工具)
* 自己new User(); user.setXXX数据
* 完成业务逻辑的代码(不推荐写在Servlet) new UserService();
* 接收结果,通过结果把显示的数据发送给JSP。(把结果存入域对象)
* M:模型层(JavaBean封装数据,其他JavaBean处理业务)
* 处理业务逻辑根据注册的功能。(用户名不能重名,邮箱不能重名)
* 需要把结果返回去。
* V:视图层(完成数据的显示)
* 到JSP的页面,通过EL表达式取域的值。
==========================================================================================================
* MySQL数据库
* 数据库
* 数据库就是一个文件系统,访问数据的时候需要通过标准的SQL语言来完成。
* 关系型的数据
* 保存的实体与实体之间的关系。(用户、商品、订单)
* 常见的数据库
* Oracle 公司Oracle(甲骨文)数据产品,收费的大型的数据库。
* MySQL 开源的,被Oracle收购了,小型的数据库。5.x版本免费,6.x收费了。
* SQLServer 微软的,收费的中型的数据库。
* DB2 IBM公司收费的大型的数据库。
* SyBASE PowerDigener软件(非常牛)
* MySQL的简介
* 卸载干净
* 找到MySQL的安装路径,找到my.ini的配置文件。
* basedir="C:/Program Files (x86)/MySQL/MySQL Server 5.5/" 安装的路径
* datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/" MySQL存储数据的路径
* 通过控制面板卸载MySQL
* 找到上面的两个路径,删除就ok了。
* 安装了
* 安装路径不要有中文(*****)
* MySQL默认端口是3306,不要修改。
* 设置MySQL的编码集(采用UTF-8的编码)
* 要把黑窗口的勾勾选上。
* 设置用户名的密码:两行都是密码,第一行是密码,第二行是确认密码。
* 安装完成。
* 访问:
cmd > 输入命令 mysql -u root -p 回车
输入密码 回车
* 密码重置
1.停止mysql服务:
services.msc 进入到服务界面
2.在cmd>输入一个命令:
mysqld --skip-grant-tables (开启一个mysql服务,不需要进行认证.)
3.新打开一个cmd窗口
mysql -u root -p 不需要输入密码.就可以进入.
4.输入命令 show databases;查看数据库,输入命令 use mysql;使用mysql数据库。
5.修改密码的语句:
update user set password=password('root') WHERE user='root';
6.将两个窗口都关闭.
7.任务管理器中结束(mysqld)进程.
8.重启mysql服务
* MySQL之间的关系(看图)
* 总结:一个数据库的服务器中有多个数据库,一个数据库中有多个表,
每个表有多个字段。字段和Java中类的属性是对应的。
每一条记录对应是一个Java实例对象。
* SQL语句(*****)
* SQL的简介
* Structured Query Language, 结构化查询语言
* 非过程性的语言
* 过程性的语言:我下一条语句,需要依赖上一条或者上几条语句。
* 非过程性的语言:写一条语句,就会执行一个结果。
* Oracle开发PL/SQL,只能在Oracle使用。
* SQL Server、Sybase的T-SQL
* SQL语言分类
* DDL(数据定义语言)
* 创建数据库、创建表
* DML(数据操纵语言)(*****)
* 插入数据(insert) 修改数据(update) 删除数据(delete)
* DCL (数据控制语言)
* if else
* DQL(数据查询语言)(*****)
* 查询数据 select
* 数据库(CURD -- 增删改查)
* 创建数据库
* 语法:create database 数据名称; 创建一个数据了。
* create database 数据库名称 character set 编码 collate 校对规则;
* 校对规则:和编码是成对出现的。
* 练习
创建一个名称为mydb1的数据库。
create database mydb1;
创建一个使用utf8字符集的mydb2数据库。
create database mydb2 character set 'utf8';
创建一个使用utf8字符集,并带校对规则的mydb3数据库。
create database mydb3 character set 'utf8' collate 'utf8_bin';
* 查看数据库 show databases;
* 查询数据库的定义 show create database 数据库;
show create database mydb2;
* 删除数据库 drop database 数据库名称;
练习
查看当前数据库服务器中的所有数据库
show databases;
查看前面创建的mydb2数据库的定义信息
show create database mydb2;
删除前面创建的mydb1数据库
drop database mydb1;
* 修改数据库
* 语法:alter database 数据库 character set 编码 collate 校对规则;
* 练习:查看服务器中的数据库,并把其中某一个库的字符集修改为gbk
alter database mydb2 character set 'gbk';
* 其他的操作
* 切换数据库(*****) use db_name;
* 查看当前使用的数据库 select database();
* 表(table)(CURD -- 增删改查)
* 语法:
create table 表名(
字段1 类型(长度) 约束,
字段2 类型(长度) 约束,
字段3 类型(长度) 约束,
字段4 类型(长度) 约束
);
注意:
* 表名小括号,后面要有分号。
* 每一行字段后面要有逗号,但是最后一行没有逗号。
* 数据的类型后面有长度,如果是字符串类型,长度必须加。如果其他类型可以不加。默认长度。int 默认长度11
public class User{
int id;
String name;
String pass;
String eamil;
String nikename;
}
* 数据的类型
字符串型
VARCHAR、CHAR
* varchar和char区别:
* varchar(经常使用) 长度是可变的。 name varchar(8) 存入数据hello,但是如果存入helloworld报错了。
* char 长度不可变的。 name char(8) 存入的数据hello,如果不够用空格补全。
* 效率高:char效果。
大数据类型(一般不用)
BLOB、TEXT
BLOB:二进制文件
TEXT:字符
数值型
TINYINT 、SMALLINT、INT、BIGINT、FLOAT、DOUBLE
逻辑性 对应boolean
BIT
日期型
DATE、TIME、DATETIME、TIMESTAMP
* date 只包含日期
* time 只包含时分秒
* datetime和timestamp包含日期和时分秒区别:
* datetime需要手动录入时间。
* timestamp不传入数据,默认选择当前系统时间。
* 练习,创建表的练习
create table employee(
id int,
name varchar(20),
gender varchar(10),
birthday date,
entry_date date,
job varchar(100),
salary double,
resume text
);
* 约束(单表)
* 主键约束(*****)
* 标识标记该条记录。 通过pramary key声明主键。(默认唯一、非空)
* auto_increment 数据库维护主键。自动增长。
* 唯一约束
* 值是唯一的。使用unique声明
* 非空约束
* 值不能为空 not null
* 创建新的标签employee2,把约束加上。
create table employee2(
id int primary key auto_increment,
name varchar(20) unique not null,
gender varchar(10) not null,
birthday date not null,
entry_date date not null,
job varchar(100) not null,
salary double not null,
resume text not null
);
* 使用desc 表名; 查看表的信息
* show tables ; 查看当前库内所有表名
* show create table 表名; 查看建表语句和字符集
* 删除表
drop table employee2;
* 修改表
alter table 表名 add 字段 类型(长度) 约束; -- 添加字段
alter table 表名 drop 字段; -- 删除字段
alter table 表名 modify 字段 类型(长度) 约束; -- 修改类型或者约束
alter table 表名 change 旧字段 新字段 类型(长度) 约束 -- 修改字段的名称
rename table 表名 to 新表名; -- 修改表名
alter table 表名 character set utf8; -- 修改字符集
* 练习
在上面员工表的基本上增加一个image列。
alter table employee add image varchar(20);
修改job列,使其长度为60。
alter table employee modify job varchar(60);
删除gender列。
alter table employee drop gender;
表名改为user。
rename table employee to user;
修改表的字符集为utf8
alter table user character set utf8;
列名name修改为username
alter table user change name username varchar(30);
* 数据(CURD -- 增删改查)(******)
* 添加数据
* insert into 表名 (字段1,字段2,字段3..) values(值1,值2,值3...); 有几列就插入多少的值。
* insert into 表名 values(值1,值2,值3...); 插入所有的列
* 注意:
* 数据与字段的类型相同。
* 字段长度需要控制。
* 字符串或者日期类型需要使用''
* 向user表中插入数据
insert into user values (1,'xiaofeng','1994-10-10','2011-1-1','HR',19000,'aaa','abc');
insert into user values (2,'美美','1994-10-10','2011-1-1','HR',19000,'aaa','abc');
insert into user values (3,'小风','1994-10-10','2011-1-1','WORKER',21000,'aaa','abc');
insert into user values (4,'芙蓉','1994-10-10','2011-1-1','HR',1000,'aaa','abc');
insert into user values (5,'班长','1994-10-10','2011-1-1','HR',100,'aaa','abc');
* 解决中文乱码的问题(*****)
[client]
port=3306
[mysql]
default-character-set=gbk
* 修改完需要重新启动服务。
* 修改语句
* 语法: update 表名 set 字段=值,字段=值... [where ]
* 如果没有where条件,默认更新所有的记录。
* 有where提交,选择某一条记录。
将所有员工薪水修改为5000元。
update user set salary=5000;
将姓名为’班长’的员工薪水修改为3000元。
update user set salary=3000 where username='班长';
将姓名为’美美’的员工薪水修改为4000元,job改为BOSS。
update user set salary=4000,job='BOSS' where username='美美';
将班长的薪水在原有基础上增加1000元。
update user set salary = salary+1000 where username='班长';
* 删除数据 delete
语法:delete from 表名 [where ]; 删除数据
truncate 表名; 删除所有的数据
* truncate 和 delete的区别:
* truncate删除数据,先删除整个表。再创建一个新的空的表。(效率)
* delete删除数据,一条一条删除的。(*****)
* 事物(insert update delete)
删除表中名称为’班长’的记录。
* delete from user where username='班长';
删除表中所有记录。
* delete from user;
使用truncate删除表中记录。
* truncate user;
* 查询语句
* 语法: select * from 表名; 查询所有(字段)
select 字段名1,字段名2,字段名3 from 表名; 显示查询字段名
select DISTINCT 字段名 from 表名; 去除重复的数据。
查询表中所有学生的信息。
select * from stu;
查询表中所有学生的姓名和对应的英语成绩。
select name,english from stu;
过滤表中重复数据。(面试题)
select distinct english from stu;
* 查询的列可以运算
* 可以使用别名:使用as 别名 并且as可以省略。
练习:
在所有学生分数上加10分特长分。
select name,math+10,english+10,chinese+10 from stu;
统计每个学生的总分。
select name,math+english+chinese from stu;
使用别名表示学生分数。
select name,(math+english+chinese) as sum from stu;
* 使用where条件过滤
查询姓名为班长的学生成绩
select * from stu where name='班长';
查询英语成绩大于90分的同学
select name,english from stu where english < 15;
查询总分大于200分的所有同学
select name,math+english+chinese from stu where (math+english+chinese) > 200;
* 常用的符号
> < <= >= = <>(不等于)
in(范围内取内容)
like -- 模糊查询 写法:like '张_或者%'; _和%区别:占位符。_只一个%可以有多个
%的写法 like '%张'; 结果XXX张
like '张%'; 结果张XXX
like '%张%'; 只要有张就行
is null -- 判断是否为null
and -- 并且
or -- 或者
not -- 不成立
* 练习
查询英语分数在 80-90之间的同学。
select * from stu where english >80 and english <90;
select * from stu where english between 80 and 90;
查询数学分数为18,78,46的同学。(in)
select * from stu where math in(18,78,46);
查询所有姓班的学生成绩。
select * from stu where name like '班%';
查询数学分>80,语文分>80的同学。
select * from stu where math >80 or chinese > 80;
* 排序 使用order by 升序默认的(asc)/降序(desc)
* 出现select的语句末尾。
练习
对数学成绩排序后输出。
select name,math from stu order by math;
对总分排序按从高到低的顺序输出
select name,math+english+chinese from stu order by (math+english+chinese) desc;
对学生成绩按照英语进行降序排序,英语相同学员按照数学降序
select * from stu order by english desc,math desc;
对姓美的学生成绩排序输出
select * from stu where name like '美%' order by english desc;
* 聚集函数
* count 获取数量
练习:
统计一个班级共有多少学生?
select count(*) from stu;
统计数学成绩大于90的学生有多少个?
select count(*) from stu where math > 90;
统计总分大于150的人数有多少?
select count(*) from stu where (math+english+chinese) > 150;
* sum 求和(忽略null值) 可以同ifnull(xxx,0)
统计一个班级数学总成绩?
select sum(math) from stu;
统计一个班级语文、英语、数学各科的总成绩
select sum(math),sum(english),sum(chinese) from stu;
统计一个班级语文、英语、数学的成绩总和
select sum(ifnull(math,0)+english+chinese) from stu;
select sum(math)+sum(english)+sum(chinese) from stu;
统计一个班级语文成绩平均分
select sum(chinese) / count(*) from stu;
* avg 平均数
练习:
求一个班级数学平均分?
select avg(math) from stu;
求一个班级总分平均分
select avg(ifnull(math,0)+english+chinese) from stu;
* max 最大值
select max(math) from stu;
* min 最小值
select min(math) from stu;
* group by 分组(一起使用) 条件过滤需要是having,不能使用where
练习:对订单表中商品归类后,显示每一类商品的总价.
select product,count(*),sum(price) from orders group by product;
练习:查询购买了几类商品,并且每类总价大于100的商品
select product,sum(price) from orders group by product having sum(price) > 100;
* 小结 select 语句 : S-F-W-G-H-O 组合 select ... from ... where ... group by... having... order by ... ;
顺序不能改变
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,'洗衣机',100);
insert into orders(id,product,price) values(3,'洗衣粉',90);
insert into orders(id,product,price) values(4,'桔子',9);
insert into orders(id,product,price) values(5,'洗衣粉',90);
insert into orders(id,product,price) values(6,'电视',900);
重置密码
1.停止mysql服务:
services.msc 进入到服务界面
2.在cmd>输入一个命令:
mysqld --skip-grant-tables (开启一个mysql服务,不需要进行认证.)
3.新打开一个cmd窗口
mysql -u root -p 不需要输入密码.就可以进入.
4.输入命令 show databases;查看数据库,输入命令 use mysql;使用mysql数据库。
5.修改密码的语句:
update user set password=password('root') WHERE user='root';
6.将两个窗口都关闭.
7.任务管理器中结束(mysqld)进程.
8.重启mysql服务
MySQL安装图解
一、MYSQL的安装
1、双击打开mysql-5.5.27-win32.msi进行安装”。
选择我同意
2、选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,选择“Custom”,按“next”键继续。
3、可以选择MySQL的安装路径和数据的安装路径。
选择MySQL Server,点击Browse.. 选择安装的路径。
还可以选择Server data files,点击Browse..选择安装的路径。
4、填上安装目录,我的是“F:\Server\MySQL\MySQL Server 5.0”,也建议不要放在与操作系统同一分区,这样可以防止系统备份还原的时候,数据被清空。按“OK”继续。
确认一下先前的设置,如果有误,按“Back”返回重做。按“Install”开始安装。
5、正在安装中,请稍候,直到出现下面的界面
点击Finish完成安装。
二、MYSQL的配置
1、安装完成了,出现如下界面将进入mysql配置向导。
2、选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration(标准配置)”,我们选择“Detailed Configuration”,方便熟悉配置过程。
3、选择服务器类型,“Developer Machine(开发测试类,mysql占用很少资源)”、“Server Machine(服务器类型,mysql占用较多资源)”、“Dedicated MySQL Server Machine(专门的数据库服务器,mysql占用所有可用资源)”
4、选择mysql数据库的大致用途,“Multifunctional Database(通用多功能型,好)”、“Transactional Database Only(服务器类型,专注于事务处理,一般)”、“Non-Transactional Database Only(非事务处理型,较简单,主要做一些监控、记数用,对MyISAM数据类型的支持仅限于non-transactional),按“Next”继续。
默认选择Next
5、选择网站并发连接数,同时连接的数目,“Decision Support(DSS)/OLAP(20个左右)”、“Online Transaction Processing(OLTP)(500个左右)”、“Manual Setting(手动设置,自己输一个数)”。
6、MySQL的默认端口号是3306,不要去修改,咱们都使用默认的端口号就OK。在这个页面上,您还可以选择“启用标准模式”(Enable Strict Mode),这样MySQL就不会允许细小的语法错误。如果是新手,建议您取消标准模式以减少麻烦。但熟悉MySQL以后,尽量使用标准模式,因为它可以降低有害数据进入数据库的可能性。按“Next”继续
7、就是对mysql默认数据库语言编码进行设置(重要),一般选UTF-8,按 “Next”继续。
8、选择是否将mysql安装为windows服务,还可以指定Service Name(服务标识名称),是否将mysql的bin目录加入到Windows PATH(加入后,就可以直接使用bin下的文件,而不用指出目录名,比如连接,“mysql.exe -uusername -ppassword;”就可以了,不用指出mysql.exe的完整地址,很方便),我这里全部打上了勾,Service Name不变。按“Next”继续。
9、询问是否要修改默认root用户(超级管理)的密码。“Enable root access from remote machines(是否允许root用户在其它的机器上登陆,如果要安全,就不要勾上,如果要方便,就勾上它)”。最后“Create An Anonymous Account(新建一个匿名用户,匿名用户可以连接数据库,不能操作数据,包括查询)”,一般就不用勾了,设置完毕,按“Next”继续。
10、确认设置无误,按“Execute”使设置生效,即完成MYSQL的安装和配置。
注意:设置完毕,按“Finish”后有一个比较常见的错误,就是不能“Start service”,一般出现在以前有安装mysql的服务器上,解决的办法,先保证以前安装的mysql服务器彻底卸载掉了;不行的话,检查是否按上面一步所说,之前的密码是否有修改,照上面的操作;如果依然不行,将mysql安装目录下的data文件夹备份,然后删除,在安装完成后,将安装生成的 data文件夹删除,备份的data文件夹移回来,再重启mysql服务就可以了,这种情况下,可能需要将数据库检查一下,然后修复一次,防止数据出错。