MySQL数据库

数据库(Database):存储数据的仓库

高效地存储和处理数据的介质(介质主要是两种:磁盘和内存)

分类

基于存储介质的不同:分为

关系型数据库(SQL)

非关系型数据库(NoSQL:Not Only SQL)

关系型数据库

大型:Oracle、DB2

中型:SQL Server、MySQL

小型:Access、SQLite等

非关系型数据库:Memcached、MongoDB、Redis(能够存到磁盘上)

关系型数据库:安全(保存磁盘,基本不可能丢失),容易理解,比较浪费空间(二维表)

非关系型数据库:效率高,不安全(断电丢失)

关系型数据库

是一种建立在关系模型(数学模型)上的数据库

关系模型包含三个方面:

数据结构:用于解决数据存储的问题,二维表(有行和列)

操作指令集合:所有SQL语句

完整性约束:表内数据约束(字段与字段)、表与表之间约束(外键)

设计

从需要存储的数据需求中分析,如果是一类数据(实体)应该设计成一张二维表:表是由表头和数据部分组成

表头:即字段名,用来规定数据的名字

数据部分:实际存储的数据单元

关系型数据库,需要维护实体内部、实体与实体之间的联系

特点

如果表中对应的某个字段没有值(数据),但是系统依然要分配空间,所以说关系型数据库比较浪费空间

关键字说明

数据库:database

数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼

DBS = DBMS + DB

DBMS:Database Management System,数据库管理系统,专门管理数据库

DBA:Database Administrator,数据库管理员

行/记录:row/record

列/字段:column/field

SQL

SQL:(Structured Query Language,结构化查询语言)

SQL分为三个部分:

DDL:(Data Definition Language,数据定义语言)用来维护存储数据的结构(数据库、表),代表指令:create(插入)、drop(删除)、alter(修改)等

DML:(Data Manipulation Language,数据操作语言)用来对数据进行操作(数据表中的内容),代表指令:insert、delete、update等。其中DML内部又单独进行了一个分类:DQL(Data Query Language,数据查询语言)如select

DCL:(Data Control Language,数据控制语言)主要是负责权限管理(用户),代表指令:grant、revoke等

交互方式

1、客户端连接认证:连接服务器、认证身份(mysql.exe -hPup)

2、客户端发送SQL指令

3、服务器接收SQL指令,并处理SQL指令,返回操作结果

4、客户端接收结果,并显示结果

5、断开连接

新增数据库

create database 数据库名字 [库选项];

库选项:用来约束数据库,分为两个选项

字符集设定:charset/character set 具体字符集(数据存储的编码格式,常用的有:GBK和UTF8)

校对集设定:collate 具体校对集(数据比较的规则)

数据库名字不能用关键字(已经被系统使用的字符)或者保留字(将来系统可能会用到的字符)

创建结果:

在数据库系统中,增加了对应的数据库信息

会在保存数据的文件夹下(Data目录),创建一个对应数据库名字的文件夹

每个数据库下都有一个opt文件,保存了库选项

查看数据库

查看所有数据库:show databases;

查看指定部分的数据库(模糊查询):show databases like 'pattern';

pattern是匹配模式

%表示匹配多个字符

_表示匹配单个字符

查看数据库的创建语句:show create database 数据库名字;

更新数据库

数据库名字不可以修改

数据库的修改仅限库选项,即字符集和校对集(校对集依赖字符集)

alter database 数据库名字 [库选项];

charset/character set [=] 字符集

collate 校对集

删除数据库

drop database 数据库名字;

新增数据表

create table [if not exists] 表名(字段名字 数据类型,……字段名字 数据类型) [表选项];

表选项:控制表的表现

字符集:charset/character set 具体字符集; -- 保证表中数据存储的字符集

校对集:collate 具体校对集

存储引擎:engine 具体的存储引擎(innodb和myisam)

方案一:

显式地指定表所属的数据库:

create table 数据库名.表名();

方案二:

隐式地指定表所属数据库

进入数据库环境:use 数据库名字;

查看数据表

查看所有表:show tables;

查看部分表(模糊查询):show tables like 'pattern';

pattern是匹配模式

%表示匹配多个字符

_表示匹配单个字符

查看表的创建语句:show create table 表名;

查看表结构(表中的字段信息):desc/describe/show columns from 表名;

修改数据表

修改表本身

修改表名:rename table 旧表名to 新表名;

修改表选项(字符集、校对集、存储引擎都可以修改):alter table 表名 表选项[=] 值;

修改字段

删除数据表:drop table 表名1,表名2……;

新增字段:alter table 表名 add [column] 字段名 数据类型 [列属性] [位置];

first:第一个位置

after:在哪个字段之后:after 字段名;

修改字段:alter table 表名 modify 字段名 数据类型 [列属性] [位置];

重命名字段:alter table 表名 change 旧字段 新字段名 数据类型 [列属性] [位置];

删除字段:alter table 表名 drop 字段名;

新增数据

方案一:给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致,凡是非数值数据,都需要使用引号(建议是单引号)包裹

insert into 表名 values(值列表)[,(值列表)];

方案二:给部分字段插入数据,需要选定字段列表,字段列表出现的顺序与字段的顺序无关,但是值列表的顺序必须与选定的字段顺序一致

insert into 表名 (字段列表) values (值列表) [,(值列表)];

查看数据

查看所有数据:select * from 表名 [where 条件];

查看指定字段、指定条件的数据:select 字段列表 from 表名 [where 条件];

更新数据

update 表名 set 字段 = 值 [where 条件];

建议都有where,否则就是更新全部

删除数据

删除是不可逆的,谨慎删除

delete from 表名 [where条件];

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容

  • MySQL数据库对象与应用 2.1-MySQL数据类型 库建立好之后基本不动,和我们接触最频繁的是表. 建表就是声...
    极客圈阅读 2,144评论 0 8
  • 什么是数据库? 数据库:database,存储仓库的介质。 数据库:高效的存储和处理数据的介质(介质主要是两种:磁...
    翊溪阅读 944评论 0 5
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,296评论 0 9
  • MySQL数据库基本操作 MySQL中数据库的类型 MySQL中的数据库分为系统数据库和用户数据库两大类。 系统数...
    刘玉鹏151阅读 434评论 0 0
  • 一、字符集 思考:计算机是只能==存储和识别二进制==的,但是人能够更好识别的内容是各种符号(文字、图片、表情等)...
    好像在哪见过你丶阅读 350评论 0 0