数据库的建立和维护功能、数据定义功能、数据操纵功能、数据库的运行管理功能、通信功能
非关系数据库也被称作NoSQL(Not Only SQL)
存储数据不以关系模型为依据,不需要固定的表格式
非关系型数据库的有点
常用的非关系数据库:Redis、mongoDB等
类型 | 解释 | 举例 |
---|---|---|
int | 整型 | 用于定义整数类型的数据(1、2、3、4、5…) |
float | 单精度浮点(4字节32位) | 准确表示小数点后六位 |
double | 双精度浮点(8字节64位) | 小数位更多,更精确 |
char | 固定长度的字符类型 | 定义字符长度(存的少,会补空格,存的多被截取,高版本报错) |
varchar | 可变长度的字符类型 | 定义字符最大长度(存的小,总长度变小,存的大于最大,报错) |
text | 文本 | |
image | 图片 | |
decimal(5,2) | 总共5个有效长度数字,小数点后面有两位 |
char和varchar的区别
截取和截断的区别
SQL语言分类
mysqladmin -u root -p password "123" #给数据库设置密码(后面的回车)
mysql -uroot -p "123" #直接登录数据库
mysql -u root -p #登录数据库,输入密码后完成登录
show databases; #查看有多少数据库(分号要加)
use mysql #进入一个数据库中,(分号可以不加)
show tables; #查看该数据库中有多少个表
2.1.3 查看表的结构
describe db; #查看表的字段属性(可缩写为desc db)
create database school; #创建一个名为school的数据库
create table hj (id int(10) not null,name varchar(40) not null,age int (3) not null,score decimal(5,2) default '0',primary key (id));
#创建一个名为hj的表,(定义id不为空,名字不为空,年龄不为空,成绩可为空默认为“0”,主键为id)
create table scholl.hj1 (id int(10) not null); # 在任意库中创建school库中的ky21表
2.2.2 删除数据库和表-drop
drop database huang #删除一个名为huang的数据库
drop table hj2 #删除一个ky22的表
drop table school.hj1 #可以再别的数据库中删除指定数据库中的表
select * from hj; #查看hj表中所有的数据
select * from \G; #友好的显示
insert into hj (id,name,age,score) values(1,'张三',18,88);
#向hj表中插入数据
insert into hj (id,name,age) values(2,'张五',18);
#向hj表中指定字段插入,(可为空的字段,可以不添加值,为默认值)
insert into hj values(3,'李四',20,67),(4,'赵四',22,90);
#批量添加表中更多数据(前面的字段不写为默认)
2.3.2 更新原有数据-update
update 表名 set 字段1=字段值1,字段2=字段值10 where 表达式;
update hj set name='小红',age=35 where name='张五';
#将字段name为zhanger的,name和age进行修改。
update hj set name='小明',age=24 where id>2;
#将id大于2的记录进行修改。
格式:delete from 表名 where 条件表达式;
delete from hj where name='小明'; #删除hj表中name为小明的记录
delete from hj where id>4; #删除hj表中id大于4的记录
delete from hj; #删除hj表中所有记录(谨慎操作)
格式:select 字段1,字段2 from 表名 【where 条件表达式】;
select * from hj; #查看整个表的所有记录
select id,name from hj; #查看整个表中的id,name字段
select id,name from hj\G #友好查看整个表的id,name,
select id,name,score from hj where name='小明'; #查看name为小明的id,namescore
select id,name from hj where score>80; #查看分数值大于80分的字段id,name ,
select * from hj limit 2; #查看前二行
select * from hj limit 2,3; #显示第2行后的3行。(不包括第2行)
alter:修改表名称或表结构
格式:alter table 旧表名 rename 新表名;
alter table hj rename yun;
alter table yun rename hj;
alter table 表名 add address varcghar(50) default '江宁区';
#表示在表中增加一个字段为:address字段。
格式:alter table 表名 change 旧列名 新列名 数据类型 【unique key】;
unique key :唯一键(特性:唯一,但可以为空,空值只允许出现一次)
primary key:主键(特性:唯一且非空)
alter table hj change name name_new varchar(50) unique key;
#change 可以修改字段名、数据类型、约束等所有项
2.5.4 删除字段
alter table 表名 drop 字段名;
alter table hj drop name_new;
sql语言的分类
DDL:数据定义语言,用于创建和删除数据库表等操作
DML:数据操纵语言,用于管理表中的记录,对数据进行增、删、改的操作
DQL:数据查询语言,主要用来查询数据库中的记录
DCL:数据控制语言,用来针对字段属性的增、删、改增操作