首页 > 数据库 > MySQL >

数据库-MYSQL安装配置和删除

2017-04-21

数据库-MYSQL安装配置和删除。


数据库-MYSQL安装配置和删除。

* 开发的功能使用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 &#39;张_或者%&#39;; _和%区别:占位符。_只一个%可以有多个

%的写法 like &#39;%张&#39;; 结果XXX张

like &#39;张%&#39;; 结果张XXX

like &#39;%张%&#39;; 只要有张就行

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 &#39;班%&#39;;

查询数学分>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 &#39;美%&#39; 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,&#39;电视&#39;,900);

insert into orders(id,product,price) values(2,&#39;洗衣机&#39;,100);

insert into orders(id,product,price) values(3,&#39;洗衣粉&#39;,90);

insert into orders(id,product,price) values(4,&#39;桔子&#39;,9);

insert into orders(id,product,price) values(5,&#39;洗衣粉&#39;,90);

insert into orders(id,product,price) values(6,&#39;电视&#39;,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(&#39;root&#39;) WHERE user=&#39;root&#39;;

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服务就可以了,这种情况下,可能需要将数据库检查一下,然后修复一次,防止数据出错。

相关文章
最新文章
热点推荐