1.数据库
1.概述
- 数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合。
- 数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中的数据。
- 数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。
- 数据库:存储、维护和管理数据的集合。
2.分类
1.关系型数据库(sql)
Oracle:是Oracle公司的数据库产品
Mysql: 最早属于瑞典的MysqlAB公司的,后被Sun公司收购,Sun在2009年4月20号被Oracle收购。
SQLServer:微软旗下的数据库产品
Access:微软旗下的数据库产品
DB2:IBM公司旗下的数据库产品
2.非关系型数据库(nosql)
HBase是一个分布式的、面向列的开源数据库
MongoDB是一个基于分布式文件存储的数据库
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API
2.SQL
1.分类
- DDL:数据定义语言,用来定义数据库对象:库、表、列等;
- DML:数据操作语言,用来定义数据库记录(数据);
- DCL:数据控制语言,用来定义访问权限和安全级别;
- DQL:数据查询语言,用来查询记录(数据)。
2.DDL
1.关键字
使用的关键字:CREATE、 ALTER、DROP
2.操作数据库
//创建**
Create database mydb1;
Create database mydb2 character set gbk;
Create database mydb3 character set gbk COLLATE gbk_chinese_ci;
//**查询**
//查看当前数据库服务器中的所有数据库
Show databases;
//查看前面创建的mydb2数据库的定义信息
Show create database mydb2;
//删除前面创建的mydb3数据库
Drop database mydb3;
// **修改**
//查看服务器中的数据库,并把mydb2的字符集修改为utf8;
alter database mydb2 character set utf8;
//**删除**
//Drop database mydb3;
//**查看当前使用的数据库**
Select database();
//**切换数据库**
Use mydb2;
3.操作表
语法:
create table 表名(
字段1 字段类型,
字段2 字段类型,
字段n 字段类型
);
常用数据类型:
int:整型
double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
char:固定长度字符串类型; char(10) 'aaa ’ 占10位
varchar:可变长度字符串类型; varchar(10) ‘aaa’ 占3为
text:字符串类型;
blob:字节类型;
date:日期类型,格式为:yyyy-MM-dd;
time:时间类型,格式为:hh:mm:ss
timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值
datetime:日期时间类型 yyyy-MM-dd hh:mm:ss
//当前数据库中的所有表**
SHOW TABLES;
//**查看表的字段信息**
DESC employee;
//**在上面员工表的基本上增加一个image列。**
ALTER TABLE employee ADD image blob;
//**修改job列,使其长度为60。**
ALTER TABLE employee MODIFY job varchar(60);
//**删除image列,一次只能删一列。**
ALTER TABLE employee DROP image;
//**表名改为user。**
RENAME TABLE employee TO user;
//**查看表格的创建细节**
SHOW CREATE TABLE user;
//**修改表的字符集为gbk**
ALTER TABLE user CHARACTER SET gbk;
//**列名name修改为username**
ALTER TABLE user CHANGE name username varchar(100);
//**备份表结构和表数据**
create table tname2 as select * from tname1;
//**备份表结构**
create table tname2 like tname1;
//**删除表**
DROP TABLE user ;
3.DML
INSERT
语法: INSERT INTO 表名(列名1,列名2 …)VALUES(列值1,列值2…);
注意:列名与列值的类型、个数、顺序要一一对应。
可以把列名当做java中的形参,把列值当做实参。
值不要超出列定义的长度。
如果插入空值,请使用null
插入的日期和字符一样,都使用单引号括起来。
练习 :
create table emp(
id int,
name varchar(100),
gender varchar(10),
birthday date,
salary float(10,2),
entry_date date,
resume text
);
//插入所有的字段时,可以省略前面的,直接写insert into values();
INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(1,'zhangsan','female','1990-5-10',10000,'2015-5-5-','good girl');
INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(2,'lisi','male','1995-5-10',10000,'2015-5-5','good boy');
INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(3,'你好','male','1995-5-10',10000,'2015-5-5','good boy');
//小知识:
//查看数据库编码的具体信息
Show variables like ‘character%’;
//临时更改客户端和服务器结果集的编码
Set character_set_client=gbk;
Set character_set_results=gbk;
UPDATE:
语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值
练习:
//将所有员工薪水修改为5000元。
UPDATE emp SET salary=5000
//将姓名为’zs’的员工薪水修改为3000元。
UPDATE emp SET salary=3000 WHERE name=’ zhangsan’;
//将姓名为’aaa’的员工薪水修改为4000元,job改为ccc。
UPDATE emp SET salary=4000,gender='female' WHERE name='lisi';
//将wu的薪水在原有基础上增加1000元。
UPDATE emp SET salary=salary+1000 WHERE gender='male';
//update的if语句,如果性别为m,改为f,否则为m
UPDATE user SET sex = IF('m','m','f')
DELETE:
语法 : DELETE FROM 表名 【WHERE 列名=值】
练习 :
//删除表中名称为’zs’的记录。
DELETE FROM emp WHERE name=‘zs’;
//删除表中所有记录。
DELETE FROM emp;
//使用truncate删除表中记录。
TRUNCATE TABLE emp;
DELETE 删除表中的数据,表结构还在;删除后的数据可以找回
TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。Truncate
删除的数据不能找回。执行速度比DELETE快。