Node.js数据库交互:MySQL实用指南

打印 上一主题 下一主题

主题 814|帖子 814|积分 2442

1、配置数据库 MySQL

1.1.1 MySQL及其安装

PhpStudy下载安装使用教程,图文教程
Database Client VsCode毗连Mysql
1.1.2基本命令

所有的语句都要以分号结尾
  1. show databases; --查看当前所有的数据库
  2. use 数据库名; --打开指定的数据库
  3. show tables; --查看所有的表
  4. describe/desc 表名; --显示表的信息
  5. create database 数据库名; --创建一个数据库
  6. exit --退出连接
复制代码
1.2.1操作数据库

1.创建数据库
  1. CREATE DATABASE [IF NOT EXISTS] 数据库名;
复制代码
2.删除数据库
  1. DROP DATABASE [if EXISTS] 数据库名;
复制代码
3.使用数据库
  1. --如果表名或者字段名是特殊字符,则需要带``
  2. use 数据库名;
复制代码
4.查看数据库
  1. SHOW DATABASES;
复制代码
1.2.2数据库的列范例

1.数值
数据范例形貌大小tiyint十分小的数据1字节smallint较小的数据2字节mediumint中等大小的数据3字节int标准的数据4字节bigint较大的数据8字节float浮点数4字节double浮点数8字节decimal字符串形式的浮点数 2.字符串
数据范例形貌大小char字符串固定大小0-255varchar可变字符串0-65535tinytext卫星文本2阶乘8-1text文本串2阶乘16-1 3.时间日期
数据范例形貌格式date日期格式YYYY-MM-DDtime时间格式HH:mm:ssdatetime最常用的时间格式YYYY-MM-DD HH:mm:sstimestamp时间戳year年份表示 4.null


  • 没有值,未知
  • 不要使用NULL值进行计算
1.2.3创建数据库表

  1. -- IF NOT EXISTS 如果不存在
  2. -- NOT NULL 非空
  3. -- AUTO_INCREMENT 自增 通常设置给id
  4. -- DEFAULT 默认值
  5. -- COMMENT 解释
  6. -- PRIMARY KEY 主键 搭配自增使用
  7. CREATE TABLE IF NOT EXISTS `student`(
  8. `id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
  9. `name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
  10. `pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
  11. `sex` VARCHAR(2) NOT NULL DEFAULT '女' COMMENT '性别',
  12. `birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
  13. `address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
  14. `email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
  15. PRIMARY KEY (`id`)
  16. )
复制代码
注意点:


  • 表名和字段只管使用``括起来
  • AUTO_INCREMENT 代表自增
  • 所有的语句背面加逗号,末了一个不加
  • 字符串使用单引号括起来
  • 主键的声明一般放在末了,便于查看
常用命令
  1. SHOW CREATE DATABASE 数据库名;-- 查看创建数据库的语句
  2. SHOW CREATE TABLE 表名;-- 查看表的定义语句
  3. DESC 表名;-- 显示表的具体结构
复制代码
1.2.4修改数据库

1.修改
修改表名 :


  • ALTER TABLE 旧表名 RENAME AS 新表名
添加字段 :


  • ALTER TABLE 表名 ADD字段名 列属性[属性]
修改字段 :


  • ALTER TABLE 表名 MODIFY 字段名 列范例[属性]
  • ALTER TABLE 表名 CHANGE 旧字段名 新字段名 列属性[属性]
删除字段


  • ALTER TABLE 表名 DROP 字段名
  1. -- 修改表名
  2. -- ALTER TABLE 旧表名 RENAME AS 新表名
  3. ALTER TABLE teacher RENAME AS teachers;
  4. -- 增加表的字段
  5. -- ALTER TABLE 表名 ADD 字段名 列属性
  6. ALTER TABLE teachers ADD age INT(11);
  7. -- 修改表的字段(重命名,修改约束)
  8. -- ALTER TABLE 表名 MODIFY 字段名 [列属性];
  9. ALTER TABLE teachers MODIFY age VARCHAR(11);-- 修改约束
  10. -- ALTER TABLE 表名 CHANGE 旧名字 新名字 [列属性];
  11. ALTER TABLE teachers CHANGE age age1 INT(1);-- 字段重命名
  12. -- 删除表的字段
  13. -- ALTER TABLE 表名 DROP 字段名
  14. ALTER TABLE teachers DROP age1;
复制代码
2.删除
语法:DROP TABLE [IF EXISTS] 表名


  • IF EXISTS为可选 , 判断是否存在该数据表
  • 如删除不存在的数据表会抛出错误
  1. -- 删除表(如果存在再删除)
  2. DROP TABLE IF EXISTS teachers;
复制代码
2、DML语言(增删改查)

2.1添加(insert)

  1. INSERT INTO `student`(`name`) VALUES ('zsr');
  2. -- 插入多条数据
  3. INSERT INTO `student`(`name`,`pwd`,`sex`) VALUES ('zsr','200024','男'),
  4. ('gcc','000421','女');
  5. -- 省略字段
  6. INSERT INTO `student` VALUES (5,'Bareth','123456','男','2000-02-04','武
  7. 汉','1412@qq.com',1);
复制代码
语法:
  1. INSERT INTO 表名([字段1,字段2..])VALUES('值1','值2'..),[('值1','值2'..)..];
复制代码
注意:

  • 字段和字段之间使用英文逗号隔开
  • 字段是可以省略的,但是值必须完整且一一对应
  • 可以同时插入多条数据,VALUES背面的值必要使用逗号隔开
2.2修改(update)

  1. -- 修改学员名字,指定条件
  2. UPDATE `student` SET `name`='zsr204' WHERE id=1;
  3. -- 不指定条件的情况,会改动所有表
  4. UPDATE `student` SET `name`='zsr204';
  5. -- 修改多个属性
  6. UPDATE `student` SET `name`='zsr',`address`='湖北' WHERE id=1;
  7. -- 通过多个条件定位数据
  8. UPDATE `student` SET `name`='zsr204' WHERE `name`='zsr' AND `pwd`='200024';
复制代码
语法:
  1. UPDATE 表名 SET 字段1=值1,[字段2=值2...] WHERE 条件[];
复制代码
关于WHERE条件语句:
操作符含义=即是<>或!=不即是>大于<小于<=小于即是>=大于即是between…and…闭合区间and和or或 2.3删除(delete)

  1. -- 删除数据(避免这样写,会全部删除)
  2. DELETE FROM `student`;
  3. -- 删除指定数据
  4. DELETE FROM `student` WHERE id=1;
复制代码
语法:
  1. DELETE FROM 表名 [WHERE 条件]
复制代码
关于 DELETE 删除的问题,重启数据库现象:


  • INNODB 自增列会从1开始(存在内存当中,断电即失)
  • MYISAM 继承从上一个子增量开始(存在内存当中,不会丢失)
TRUNCATE
作用:完全清空一个数据库表,表的结构和索引约束不会变!
2.4查询数据(select)

  1. SELECT [ALL | DISTINCT]
  2. {* | table.* | [table.field1[as alias1][,table.field2[as alias2]][,...]]}
  3. FROM table_name [as table_alias]
  4. [left | right | inner join table_name2] -- 联合查询
  5. [WHERE ...] -- 指定结果需满足的条件
  6. [GROUP BY ...] -- 指定结果按照哪几个字段来分组
  7. [HAVING] -- 过滤分组的记录必须满足的次要条件
  8. [ORDER BY ...] -- 指定查询记录按一个或多个条件排序
  9. [LIMIT {[offset,]row_count | row_countOFFSET offset}]; -- 指定查询的记录从哪条
  10. 至哪条
复制代码


  • 查询数据库数据 , 如SELECT语句
  • 简朴的单表查询或多表的复杂查询和嵌套查询
  • 是数据库语言中最核心,最重要的语句
  • 使用频率最高的语句
2.4.1基础查询
语法:
  1. SELECT 查询列表 FROM 表名;
复制代码


  • 查询列表可以是:表中的(一个或多个)字段,常量,变量,表达式,函数
  • 查询结果是一个虚拟的表格
  1. -- 查询全部学生
  2. SELECT * FROM student;
  3. -- 查询指定的字段
  4. SELECT `LoginPwd`,`StudentName` FROM student;
  5. -- 别名 AS(可以给字段起别名,也可以给表起别名)
  6. SELECT `StudentNo` AS 学号,`StudentName` AS 学生姓名 FROM student AS 学生表;
  7. -- 函数 CONCAT(str1,str2,...)
  8. SELECT CONCAT('姓名',`StudentName`) AS 新名字 FROM student;
  9. -- 查询系统版本(函数)
  10. SELECT VERSION();
  11. -- 用来计算(计算表达式)
  12. SELECT 100*53-90 AS 计算结果;
  13. -- 查询自增步长(变量)
  14. SELECT @@auto_increment_increment;
  15. -- 查询有哪写同学参加了考试,重复数据要去重
  16. SELECT DISTINCT `StudentNo` FROM result;
复制代码
2.4.2条件查询
where 条件字句:检索数据中 符合条件 的值
语法:
  1. select 查询列表 from 表名 where 筛选条件;
复制代码
  1. -- 查询考试成绩在95~100之间的
  2. SELECT `StudentNo`,`StudentResult` FROM result
  3. WHERE `StudentResult`>=95 AND `StudentResult`<=100;
  4. -- &&
  5. SELECT `StudentNo`,`StudentResult` FROM result
  6. WHERE `StudentResult`>=95 && `StudentResult`<=100;
  7. -- BETWEEN AND
  8. SELECT `StudentNo`,`StudentResult` FROM result
  9. WHERE `StudentResult`BETWEEN 95 AND 100;
  10. -- 查询除了1000号以外的学生
  11. SELECT `StudentNo`,`StudentResult` FROM result
  12. WHERE `StudentNo`!=1000;
  13. -- NOT
  14. SELECT `StudentNo`,`StudentResult` FROM result
  15. WHERE NOT `StudentNo`=1000;
  16. -- 查询名字含d的同学
  17. SELECT `StudentNo`,`StudentName` FROM student
  18. WHERE `StudentName` LIKE '%d%';
  19. -- 查询名字倒数第二个为d的同学
  20. SELECT `StudentNo`,`StudentName` FROM student
  21. WHERE `StudentName` LIKE '%d_';
  22. -- 查询1000,1001学员
  23. SELECT `StudentNo`,`StudentName` FROM student
  24. WHERE `StudentNo` IN (1000,1001);
复制代码
2.4.3分组查询
语法:
  1. select 分组函数,分组后的字段
  2. from 表
  3. 【where 筛选条件】
  4. group by 分组的字段
  5. 【having 分组后的筛选】
  6. 【order by 排序列表】
复制代码
区别:
使用关键字筛选的表位置分组前筛选where原始表group by的前面分组后筛选having分组后的结果group by的背面
  1. -- 查询不同科目的平均分、最高分、最低分且平均分大于90
  2. -- 核心:根据不同的课程进行分组
  3. SELECT
  4. SubjectName,AVG(StudentResult),MAX(`StudentResult`),MIN(`StudentResult`)
  5. FROM result r
  6. INNER JOIN `subject` s
  7. on r.SubjectNo=s.SubjectNo
  8. GROUP BY r.SubjectNo
  9. HAVING AVG(StudentResult)>90;
复制代码
2.4.4排序和分页
1.排序
语法:
  1. select 查询列表
  2. from 表
  3. where 筛选条件
  4. order by 排序列表 asc/desc
复制代码
order by的位置一般放在查询语句的末了
asc升序,假如不写默认升序desc降序
  1. SELECT `StudentNo`,`StudentName`,`GradeName`
  2. FROM student s
  3. INNER JOIN grade g
  4. ON s.GradeID=g.GradeID
  5. ORDER BY `StudentNo` DESC;
复制代码
2.分页
语法:
  1. select 查询列表
  2. from 表
  3. limit offset,pagesize;
  4. -- 第一页 limit 0 5
  5. -- 第二页 limit 5,5
  6. -- 第三页 limit 10,5
  7. -- 第n页 limit (n-1)*pagesize,pagesize
  8. -- pagesize:当前页面大小
  9. -- (n-1)*pagesize:起始值
  10. -- n:当前页面
  11. -- 数据总数/页面大小=总页面数
  12. -- limit n 表示从0到n的页面
复制代码


  • offset代表的是起始的条目索引,默认从0开始
  • size代表的是表现的条目数
  • offset=(n-1)*pagesize
2.4.5MYSQL函数

1.常用函数
  1. -- 数学运算
  2. SELECT ABS(-8); -- 绝对值
  3. SELECT CEIL(5.1); -- 向上取整
  4. SELECT CEILING(5.1); -- 向上取整
  5. SELECT RAND(); -- 返回0~1之间的一个随机数
  6. SELECT SIGN(-10); -- 返回一个数的符号;0返回0;正数返回1;负数返回-1
  7. -- 字符串函数
  8. SELECT CHAR_LENGTH('我喜欢你'); -- 字符串长度
  9. SELECT CONCAT('我','喜欢','你'); -- 拼接字符串
  10. SELECT INSERT('我喜欢',1,1,'超级') -- INSERT(str,pos,len,newstr) 从str的pos位置
  11. 开始替换为长度为len的newstr
  12. SELECT UPPER('zsr'); -- 转大写
  13. SELECT LOWER('ZSR'); -- 转小写
  14. SELECT INSTR('zsrs','s'); -- 返回第一次出现字串索引的位置
  15. SELECT REPLACE('加油就能胜利','加油','坚持'); -- 替换出现的指定字符串
  16. SELECT SUBSTR('坚持就是胜利',3,6); -- 返回指定的字符串(源字符串,截取位置,截取长度)
  17. SELECT REVERSE('rsz'); -- 反转字符串
  18. -- 时间日期函数
  19. SELECT CURRENT_DATE(); -- 获取当前日期
  20. SELECT CURDATE(); -- 获取当前日期
  21. SELECT now(); -- 获取当前时间
  22. SELECT LOCALTIME(); -- 本地时间
  23. SELECT SYSDATE(); -- 系统时间
  24. SELECT YEAR(NOW());
  25. SELECT MONTH(NOW());
  26. SELECT DAY(NOW());
  27. SELECT HOUR(NOW());
  28. SELECT MINUTE(NOW());
  29. SELECT SECOND(NOW());
  30. -- 系统信息
  31. SELECT SYSTEM_USER();
  32. SELECT USER();
  33. SELECT VERSION();
复制代码
2.聚合函数
函数形貌max最大值min最小值sum和avg均匀值count计算个数
  1. SELECT COUNT(StudentName) FROM student;
  2. SELECT COUNT(*) FROM student;
  3. SELECT COUNT(1) FROM student;
  4. SELECT SUM(`StudentResult`) FROM result;
  5. SELECT AVG(`StudentResult`) FROM result;
  6. SELECT MAX(`StudentResult`) FROM result;
  7. SELECT MIN(`StudentResult`) FROM result;
复制代码
总结:本文详细介绍了MySQL数据库的配置、基本命令、数据范例、表的创建与修改、DML语言(增删改查)以及常用函数的应用,为数据库管理和操作提供了全面的指导

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

张国伟

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表