Mysql数据库基础知识详解一:语法和概述

数据库概述

  • 什么是数据库

数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作。

  • 什么是数据库管理系统

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

SQL语句

结构化查询语言(Structured Query Language)简称SQL,是关系型数据库管理系统都需要遵循的规范。不同的数据库生产厂商都支持SQL语句,但都有特有内容。即大家说的数据库方言。

SQL语句分类

  • 数据定义语言:

简称DDL(Data Definition Language),用来定义数据库对象:数据库,表,列等。关键字:create,alter,drop

  • 数据操作语言

简称DML(Data Manipulation Language),用来对数据库中表的记录进行更新。关键字:insert,delete,update

  • 数据控制语言

简称DCL(Data Control Language),用来定义数据库的访问权限和安全级别,及创建用户。

  • 数据查询语言

简称DQL(Data Query Language),用来查询数据库中表的记录。关键字:select,from,where,group by, order by ,having

SQL通用语法

SQL通用语法:
1.SQL语句可以单行或多行书写,以分号结尾
2.可使用空格和缩进来增强语句的可读性
3.MySQL数据库的SQL语句不区分大小写,关键字建议使用大写
4.同样可以使用/**/的方式完成注释

MySQL中的我们常使用的数据类型如下:
了解详情请访问:SQL数据类型

DDL之数据库操作

1.创建数据库

格式:
create database 数据库名;
create database 数据库名 character set 字符集;
例如:

#创建数据库 数据库中数据的编码采用的是安装数据库时指定的默认编码 utf8
CREATE DATABASE webdb_1; 
#创建数据库 并指定数据库中数据的编码
CREATE DATABASE webdb_2 CHARACTER SET utf8;
  1. 查看数据库
    格式:
    show databases;(查看当前所有数据库)
    查看某个特定的数据库:
    show create database 数据库名;
    例如:
    show create database webdb_1;
  2. 删除数据库
    格式:
    drop database 数据库名称;
    例如:
    drop database webdb_2;
  3. 使用数据库
    查看正在使用的数据库:
    格式:
    select database();
    .切换数据库:
    use 数据库名;
    例如:
    use webdb_1;

DDL之表操作

  1. 创建表
    格式:
create table 表名(
   字段名 类型(长度) [约束],
   字段名 类型(长度) [约束],
   ...
);

类型: varchar(n) 字符串
int 整形
double 浮点 d
ate 时间
timestamp 时间戳
约束:(后面详解)primary key 主键,被主键修饰字段中的数据,不能重复、不能为null。
例如:

###创建分类表
CREATE TABLE category (
  cid INT primary key, #分类ID 
  cname VARCHAR(100) #分类名称
);
  1. 查看表
    查看数据库中的所有表:
    格式:show tables;

查看表结构:
格式:desc 表名;
例如:desc category;

  1. 删除表
    格式:drop table 表名;
    例如:drop table category;

  2. 修改表结构格式

  • 修改表添加列
    格式:alter table 表名 add 列名 类型(长度) [约束];
#1,为分类表添加一个新的字段为 分类描述 varchar(20)
ALTER TABLE category ADD `desc` VARCHAR(20);
  • 修改表修改列的类型长度及约束.
    格式:alter table 表名 modify 列名 类型(长度) 约束;
#2, 为分类表的描述字段进行修改,类型varchar(50) 添加约束 not null
ALTER TABLE category MODIFY `desc` VARCHAR(50) NOT NULL;

注意:如果有数据,必须注意数据类型varchar–>int 容易有错误数据,需修改可转换的数据方可执行

  • 修改表修改列名.
    格式:alter table 表名 change 旧列名 新列名 类型(长度) 约束;
#3, 为分类表的分类名称字段进行更换 更换为 description varchar(30)
ALTER TABLE category CHANGE `desc`description VARCHAR(30);
  • 修改表删除列.
    格式:alter table 表名 drop 列名;
#4, 删除分类表中description这列
ALTER TABLE category DROP description;

注意: 如果列中有数据,数据就会一起删除了,需谨慎

  • 修改表名
    格式:rename table 表名 to 新表名;
#5, 为分类表category 改名成 category2
RENAME TABLE category TO category2;
  • 修改表的字符集
    格式:alter table 表名 character set 字符集
#6, 为分类表 category 的编码表进行修改,修改成 gbk
ALTER TABLE category CHARACTER SET gbk;

注意:不建议执行,可能出现乱码

DML数据操作语言

即为开发中常使用的insert,update,delete语句。

  • 插入表记录:insert
    语法:
-- 向表中插入某些字段
insert into(字段1,字段2,字段3..) values  (1,2,3..); 
--向表中插入所有字段,字段的顺序为创建表时的顺序
insert intovalues (1,2,3..);

注意:
值与字段必须对应,个数相同,类型相同,顺序相同
值的数据大小必须在字段的长度范围内
除了数值类型外,其它的字段类型的值必须使用引号引起。(建议单引号)
如果要插入空值,可以不写字段,或者插入 null

  • 更新表记录:update
    语法:
--更新所有记录的指定字段
update 表名 set 字段名=,字段名=,...;
--更新符合条件记录的指定字段
update 表名 set 字段名=,字段名=,... where 条件过滤;

注意:
列名的类型与修改的值要一致.
修改值得时候不能超过最大长度.
除了数值类型外,其它的字段类型的值必须使用引号引起

  • 删除记录:delete
    语法格式:
delete from 表名 [where 条件];
或者
truncate table 表名;

注意:
删除表中所有记录使用delete from 表名; 还是用truncate table 表名; 删除方式:
delete一条一条删除,不清空auto_increment记录数。
truncate直接将表删除,重新建表,auto_increment将置为零,从新开始。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值