数据库day01(1)

来源:互联网 发布:seo关键词工具有哪些 编辑:程序博客网 时间:2024/06/02 06:13

数据库概述

数据库(DataBase,DB)

长期保存在计算机上的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合(文件系统)

数据库管理系统(DB Management System,DBMS)

指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库的数据

DB与DBMS

数据库软件—>DBMS
数据库是通过数据库管理系统创建和操作的。
数据库:存储、维护和管理数据的集合


常见的数据库管理系统

Oracle

运行稳定、功能齐全、性能超群、技术领先。

DB2

IBM的产品。

SQL Server

微软产品,界面友好、易学易用。

PostgreSQL

支持关系和面向对象的数据库。

MySQL

免费、体积小、速度快、成本低、开源。2008年被SUN收购,2009年SUN被Oracle收购。


MySQL安装及配置

安装略。。。

启动MySQL服务

net start mysql(管理员模式下运行cmd)

停止MySQL服务

net stop mysql

登录MySQL

mysql -uroot -p 密码

退出MySQL

exit 或 quit

修改密码

1) 停止mysql服务 运行输入services.msc 停止mysql服务或者 cmd --> net stop mysql
2) 在cmd下 输入 mysqld --skip-grant-tables 启动服务器 光标不动 (不要关闭该窗口)
3) 新打开cmd 输入mysql -u root -p 不需要密码
use mysql;
update user set password=password('abc') WHERE User='root';
4) 关闭两个cmd窗口 在任务管理器结束mysqld 进程
5) 在服务管理页面 重启mysql 服务
密码修改完成

查看数据库

show databases;


数据库服务器、数据库和表

这里写图片描述
数据库包含多个表,数据库服务器即数据库管理程序,管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。
这里写图片描述
列:字段
行:一条记录(实体、对象)
一条记录对应一个类对象。


SQL概述

DBMS通过SQL(结构化查询语言)来定义和操作数据、维护数据的完整性和安全性,以及进行各种数据库的管理等。
SQL(Structure Query Language,结构化查询语言)

SQL优点:

1)几乎所有重要的DBMS都支持SQL;
2)简单易学,由描述性很强的英语单词组成;
3)高度费过程化,即用SQL操作数据库,只需指明“做什么”,无需指明“怎么做”。


SQL分类

1)DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
CREATE、 ALTER、DROP
2)DML(Data Manipulation Language):数据操作语言,用来定义数据库记录;
INSERT、 UPDATE、 DELETE
3)DQL(Data Query Language):数据查询语言,用来查询记录(数据);
SELECT
4)DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别。
sql语言以分号“;”结束


DDL—操作数据库、表、列等

1、操作数据库

使用关键字:CREATE、ALTER、DROP

1.1创建CREATE

语法
CREATE {DATABASE | SCHEMA} {IF NOT EXISTS} db_name [create_specification ,[create_specification]...]
create_specification:
[DEFAULT] CHARACTER SET charset_name//指定字符集(默认为utf8)
| [DEFAULT] COLLATE collation_name//指定数据库字符集的比较方式
举例
1、创建一个名称为mydb1的数据库
CREATE DATABASE mydb1;
2、创建一个使用gbk字符集的mydb2数据库
create database mydb2 character set gbk;
3、创建一个使用gbk字符集,并带校对规则的mydb3数据库
create database mydb4 character set gbk COLLATE gbk_chinese_ci;
校对规则:show character set查询字符集及对应的校对规则

1.2查询

查看当前数据库服务器中所有数据库
show databases;
查看前面创建过的mydb2数据库的定义信息
show create database mydb2;

1.3修改

语法
ALTER DATABASE [IF NOT EXISTS] db_name [alter_specification [, alter_specification]...]
alter_specification:
[DEFAULT] CHARACTER SET charset_name |
[DEFAULT] COLLATE collation_name
举例
1、查看服务器中的数据库,并将mydb2的字符集修改为utf8
alter database mydb2 character set utf8

1.4删除

语法
DROP DATABASE [IF NOT EXISTS] db_name
举例
1、删除前面创建的mydb3数据库
drop database mydb3;

其他

1、使用数据库
use db_name;
2、查看当前使用的数据库
select database();

2、操作表

2.1创建表

语法
create table 表名(
字段1 字段类型,
字段2 字段类型,
...
字段n 字段类型
);

常用数据类型
int:整型
double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
char:固定长度字符串类型; char(10) ‘abc ’
没有string类型,没有双引号,只有单引号
varchar:可变长度字符串类型;varchar(10) ‘abc’
text:字符串类型;
blob:字节类型;(存储图片、视频、音频等)
date:日期类型,格式为:yyyy-MM-dd;
time:时间类型,格式为:hh:mm:ss
timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值
datetime:日期时间类型 yyyy-MM-dd hh:mm:ss
这里写图片描述
举例
这里写图片描述
mysql> create table emp(
-> id int,
-> name varchar(50),
-> gender varchar(10),
-> birthday date,
-> entry_data date,
-> job varchar(100),
-> salary double,
-> resume varchar(200)
-> );

2.2其他

1、当前数据库中的所有表
SHOW TABLES
2、查看表的字段信息
DESC table_name
3、在上面的员工表的基本上增加一个image列
ALTER TABLE emp ADD image blob;
4、修改某个字段
举例:修改job列,使其长度为60
alter table emp modify job varchar(60);
5、删除列,每次只能删除一个列
举例:删除image列
alter table emp drop image;
6、改表名
rename table old_name to new_name;
7、查看表的创建细节
show create table table_name;
8、修改表的字符集为gbk
ALTER TABLE table_name CHARACTER SET gbk;
9、修改列名
ALTER TABLE table_name CHANGE old_name new_name type_name
10、删除表
DROP TABLE table_name


DML(重要)

DML是对表中数据进行增、删、改的操作
关键字:INSERT、UPDATE、DELETE
在mysql中,字符串类型和日期类型都要用单引号括起来。(’tom’, ‘2015-09-12’)
空值:null(不占内存)

1、查询表中的所有数据

SELECT * FROM table_name;

2、插入,INSERT

语法:
INSERT INTO 表名(列名1,列名2...) VALUES(列值1,列值2...);
注意
1)**列名与列值的类型、个数、顺序要一一对应。
2)可以把列名当做形参,列值当做实参。
3)值不要超出列定义的取值范围。
举例
--创建表
create table emp(
-> id int,
-> name varchar(50),
-> gender varchar(10),
-> birthday date,
-> entry_data date,
-> job varchar(100),
-> salary double,
-> resume varchar(200)
-> );

--插入数据
INSERT INTO emp(id, NAME, gender, birthday, entry_date, job, salary, RESUME)
VALUES(1, 'tom', 'male', '2017-08-30', '2017-08-30', 'engineer', 10000, 'good boy');

注意
若需对所有列名都赋值,则可以省略列名,直接赋列值,即insert into 表名 values(列值1, 列值2,...);

3、修改操作,UPDATE

语法
UPDATE 表名 SET 列名1=列值1, 列名2=列值2,... WHERE 列名=值
其中WHERE表示筛选条件(相当于if),若无筛选条件,则可省略WHERE

4、删除操作,DELETE

语法
DELETE FROM 表名 [WHERE 列名=列值]

TRUNCATE TABLE 表名

DELETE删除表中数据,但表结构还在,删除后的数据可以找回;
TRUNCATE是先把表直接drop掉,再创建一个同样的新表,删除的数据不能找回。执行速度比DELETE块。