MYSQL<一>
时间:2021-07-01 10:21:17
帮助过:6人阅读
-- ########## 01、数据库概述 ##########
2 -- 1、信息:现实世界中各种可以接触到的东西
3 -- 2、数据:信息在计算机世界中的映射(反映)
4
5 -- Java中可以把数据存储在内存中的各种容器里,但是电脑掉电后(或程序关闭后),存储在内存中的这些数据就被擦除掉了
6
7 -- 为了解决数据持久化的问题,人类提出了各种解决方案,比如:结绳记事、文字出现(记在石头上、乌龟壳上、竹简上、纸上)、计算机的使用(单个文件、文件系统、数据库)
8
9 -- 解决的核心问题:
10 -- 1、数据的持久化问题(比如:使用头脑记忆会忘记)
11 -- 2、大量数据的管理问题
12
13 -- 数据库(DataBase)是按照数据结构来进行组织、存储和管理数据的仓库
14
15 -- 数据库特点:
16 -- 1、实现数据共享
17 -- 2、减少数据的冗余
18 -- 3、保证数据的独立性
19 -- 4、实现数据的集中控制
20 -- 5、数据的完整性和一致性
21 -- 6、数据的故障修复
22
23 -- 数据库的分类(依据数据类型 和 发展历史)
24 -- 1、层次型数据模型 -----> 层次型数据库
25 -- 2、网状型数据模型 -----> 网状型数据库
26 -- 3、关系型数据模型 -----> 关系型数据库(理论依据:关系代数)
27
28 -- 主流数据库:
29 -- 关系型数据库:MySQL(甲骨文公司)、Oracle(甲骨文公司)、SQLServer(微软)、DB2(IBM)
30 -- 非关系型数据库(NoSQL):Mongodb、HBase、Cassandra等等
31
32 -- MySQL数据库:
33 -- 特点:体积小、功能比较强大、开源免费(企业特别看重)、应用广泛
34 -- 国内互联网三巨头BAT:都有自己针对MySQL的定制版本
35
36 -- MySQL数据库引擎:早期MySQL数据库默认引擎使用MyISAM引擎,较新的版本默认引擎改为使用InnoDB引擎
37 -- 1、MyISAM引擎:查询和增删速度较快,但是不支持事务
38 -- 2、InnoDB引擎:支持事务,是作为关系型数据库MySQL的首选引擎
39
40 -- MySQL数据库环境的搭建:
41 -- 1、安装
42 -- 2、设置
43 -- 3、查看MySQL服务是否开启,输入命令:services.msc
44 -- 4、在命令行窗口输入:mysql -uroot -p设置的密码
45 -- 如果看见Welcome to MySQL monitor...字样,说明安装和配置均成功
46
47 -- ########## 02、MySQL数据库语法 ##########
48 -- MySQL数据库语法
49 -- MySQL编码规范:
50 -- 1、在MySQL中编写的SQL语句均以英文分号;结尾
51 -- 2、强制要求SQL语句中的关键字使用大写,其他小写
52 -- 3、命名时,由多个单词组成的命名,多个单词之间使用下划线_连接
53
54 -- SQL语言:结构化查询语言(Structured Query Language)
55 -- 1、数据定义语言DDL:CREATE、DROP、ALTER、TRUNCATE
56 -- 2、数据操作语言DML:INSERT、UPDATE、DELETE
57 -- 3、数据查询语言DQL:SELECT
58 -- 4、数据控制语言DCL:COMMIT、ROLLBACK
59
60 -- SQL文件:保存为.sql后缀名的文件
61 -- SQL语句的注释:使用--两个中横线,接上需要注释的内容
62
63 -- 数据定义语言DDL
64 -- 对于数据库的库的理解:类比超市,超市中有多个区域,分别卖不同的商品,比如:生鲜、水果、肉类等
65
66 -- MySQL数据库中库的概念:database
67
68 -- 查看MySQL数据库中所有的库:(默认有四个库:information_schema、mysql、performance_schema、test)
69 -- 注意:这四个库,前三个都是和MySQL数据系统有关的库,平时不操作,test这个库是留给我们随意使用的
70 SHOW DATABASES;
71
72 -- 创建库
73 CREATE DATABASE 数据库名;
74
75 -- 删除库
76 DROP DATABASE 数据库名;
77
78 -- 查看MySQL数据库所支持的引擎类型(查看列的结果中Support列,标为YES或DEFAULT默认的都是支持的引擎类型,标为NO是不支持的引擎类型)
79 SHOW ENGINES \g;
80
81 -- 既然MySQL数据库中可以有多个database库,所以使用时,首先需要显式的说明要使用的是哪一个database库
82 USE 需要使用的数据库名;
83
84 -- 对于数据库的库中的表的理解:类比超市,不同的区域中有若干个货架用来摆放商品
85
86 -- MySQL数据库真的某个库中会有若干个表:table,回想关系型数据库,这些表其实就是关系的体现
87 -- 表的特征通过字段:field来进行体现
88
89 -- 查看使用的这个库中所有的表
90 SHOW TABLES;
91
92 -- 创建表
93 -- CREATE TABLE 表名
94 -- (
95 -- 字段名1 数据类型,
96 -- 字段名2 数据类型,
97 -- ...
98 -- 字段名n 数据类型
99 -- );
100
101 -- 最常用的数据类型
102 -- INT:整型
103 -- VARCHAR(长度):字符型
104
105 -- 查看表结构
106 -- 写法1
107 DESC 表名;
108 -- 写法2
109 DESCRIBE 表名;
110
111 -- 修改表名
112 ALTER TABLE 旧表名 RENAME 新表名;
113
114 -- 修改表的字段的数据类型
115 ALTER TABLE 表名 MODIFY 字段名 数据类型;
116
117 -- 修改表的字段名 和 数据类型
118 ALTER TABLE 表名 CHANGE 旧字段名 新字段名 新数据类型;
119
120 -- 添加字段(使用FIRST关键字把需要的字段添加在表结构的最前面,使用AFTER关键字把需要的字段添加在指定字段的后面)
121 ALTER TABLE 表名 ADD 新字段名 数据类型 FIRST;
122 ALTER TABLE 表名 ADD 新字段名 数据类型 AFTER 已存在的字段名;
123
124 -- 删除字段
125 ALTER TABLE 表名 DROP 字段名;
126
127 -- 删除表
128 DROP TABLE 表名;
129
130 -- ########## 03、MySQL的基本增删改查操作 ##########
131 -- 使用命令行编码SQL语句,效率低下,考虑使用图形化客户端工具,例如:MySQL Work Bench、Navicat等,经过反复比较,推荐使用SQLyog
132
133 -- 重音符`:在MySQL的SQL语句中使用特殊字符(关键字)时,一般会考虑使用重音符`,键盘位置一般在ESC键下方
134
135 CREATE TABLE userinfo
136 (
137 userid INT,
138 username VARCHAR(10),
139 `password` VARCHAR(10)
140 );
141
142 DESC userinfo;
143
144 -- 1、新增数据 INSERT
145 -- A:完整插入形式:INSERT INTO 表名(字段1, 字段2, ..., 字段n) VALUES(值1, 值2,..., 值n);
146 INSERT INTO userinfo(userid, username, `password`) VALUES(1, ‘张三‘, ‘123‘);
147 -- B:简写插入形式:INSERT INTO 表名 VALUES(值1, 值2,..., 值n);
148 INSERT INTO userinfo VALUES(2, ‘李四‘, ‘456‘);
149 -- C:插入多行形式:
150 -- 早期版本:INSERT INTO 表名 VALUES(值1, 值2,..., 值n);INSERT INTO 表名 VALUES(值11, 值12,..., 值1n);
151 INSERT INTO userinfo VALUES(3, ‘王五‘, ‘789‘);
152 INSERT INTO userinfo VALUES(4, ‘赵六‘, ‘999‘);
153 -- 后续版本:INSERT INTO 表名 VALUES(值1, 值2,..., 值n), (值11, 值12,..., 值1n);
154 INSERT INTO userinfo VALUES(5, ‘小明‘, ‘888‘), (6, ‘小红‘, ‘777‘);
155
156 -- 注意:空值 和 空串
157 -- 空串:‘‘,一对单引号包含的内容
158 INSERT INTO userinfo VALUES(7, ‘小张‘, ‘‘);
159 -- 空值:NULL,特殊值
160 INSERT INTO userinfo VALUES(8, ‘小李‘, NULL);
161 -- 下句插入的是字符串NULL
162 INSERT INTO userinfo VALUES(9, ‘小王‘, ‘NULL‘);
163
164 -- 2、修改数据 UPDATE
165 -- A:修改单个字段的值:UPDATE 表名 SET 字段名 = 新值 WHERE 条件子句;(注意:通过WHERE条件限定范围)
166 UPDATE userinfo SET `password` = ‘666‘ WHERE username = ‘赵六‘;
167 UPDATE userinfo SET `password` = ‘999‘ WHERE userid = 4;
168 UPDATE userinfo SET `password` = ‘666‘ WHERE username = ‘赵六‘ AND userid = 4;
169 -- B:修改多个字段的值:UPDATE 表名 SET 字段名1 = 新值1, 字段名2 = 新值2, ..., 字段名n = 新值n WHERE 条件子句;(注意:特别注意SET后多个字段赋值之间使用的是英文逗号)
170 UPDATE userinfo SET username = ‘赵云‘, `password` = ‘999‘ WHERE userid = 4;
171 UPDATE userinfo SET username = ‘赵六‘, `password` = ‘666‘ WHERE username = ‘赵云‘;
172 UPDATE userinfo SET username = ‘赵云‘, `password` = ‘999‘ WHERE username = ‘赵六‘ AND userid = 4;
173
174 -- 3、删除数据 DELETE TRUNCATE
175 -- A:删除满足条件的数据:DELETE FROM 表名 WHERE 条件子句;(注意:通过WHERE条件限定范围)
176 DELETE FROM userinfo WHERE `password` = ‘777‘;
177 -- B:删除全部数据:
178 -- 写法1:不使用WHERE子句的DELETE:DELETE FROM 表名;
179 DELETE FROM userinfo;
180 -- 写法2:使用TRUNCATE TABLE 表名;(注意:TRUNCATE常常翻译为截断和数据库的表的数据内容的联系)
181 TRUNCATE TABLE userinfo;
182
183 -- 最简单的查询
184 SELECT * FROM userinfo;
MYSQL<一>
标签:字段名 英文 编写 字符串 mod 范围 sql语句 管理 form