温故而知新——MYSQL基本操作
相关连接:
mysql和sqlserver的区别:https://www.cnblogs.com/vic-tory/p/12760197.html
sqlserver基本操作:https://www.cnblogs.com/vic-tory/p/12760871.html
一.创建数据库
CREATE DATABASE IF NOT EXISTS student; DROP DATABASE `student`;
二.表
CREATE TABLE IF NOT EXISTS `user`(
userId int PRIMARY KEY AUTO_INCREMENT,
userName varchar(20) NOT NULL,
userSex char(1) CHECK(userSex='男' OR userSex='女'), #MYSQL不支持检查约束
createTime timestamp DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
userPhone varchar(20) UNIQUE
); CREATE TABLE company (`companyId` int PRIMARY KEY AUTO_INCREMENT,`companyName` varchar(20) NOT NULL); ALTER TABLE `user` ADD `userAge` int COMMENT '用户年龄'; #添加字段 ALTER TABLE `user` MODIFY COLUMN `userAge` int NOT NULL COMMENT '用户年龄'; #修改字段 ALTER TABLE `user` DROP COLUMN `userAge`; #删除字段 ALTER TABLE `user` ADD CONSTRAINT FK_userId_companyId FOREIGN KEY (`companyId`) REFERENCES `company`(`companyId`); DESC `user`; DROP TABLE `user`;
三.添加
INSERT INTO `user` SET `userName`='Robin',`userSex`='男', `userPhone`='123456789',`userAge`=18;
INSERT INTO `user`(`userName`,`userSex`,`userPhone`,`userAge`,`createTime`) VALUES ('Robin','男','123456','18','2019-04-06');
INSERT INTO `user` SELECT * FROM `#user`;#一般用于表的数据添加到主表
四.查询
SELECT MAX(`createTime`),MIN(`createTime`),COUNT(*) AS count,AVG(`userAge`),SUM(`userAge`),userId,userName
FROM `user`
WHERE `userSex` ='男'
GROUP BY `userSex`,`userId`,`userName`
HAVING MIN(`createTime`)>'2019-04-05'
ORDER BY `userId` DESC /*ASC*/ ; SELECT * FROM `user` WHERE `userId` IN /*NOT IN*/(SELECT `userId` FROM `user`); SELECT * FROM `user` LIMIT 0,1; SELECT * FROM `user` WHERE EXISTS /*NOT EXISTS*/(SELECT * FROM `user` WHERE `userId`='3'); #EXISTS 返回TRUE 或者FALSE SELECT * FROM `user` u LEFT JOIN /*INNER JOIN,LEFT OUTER JOIN,RIGHT OUTER JOIN,RIGHT JOIN ,CROSS JOIN*/ `company` c ON u.companyId=c.companyId ; SELECT * FROM `user` UNION /*UNION ALL*/ SELECT * FROM `user`; SELECT DISTINCT `userName`,`userSex` FROM `user`;
五.更新
UPDATE `user` SET `userAge`=20 WHERE `userId` =1; UPDATE `user` u JOIN `company` c ON u.companyId=c.companyId
SET c.companyName='BCD',u.userName='RoBin'
WHERE u.userId='1'
六.删除
DELETE FROM `user` WHERE `userId`='1'; TRUNCATE `user`;
七.视图
CREATE VIEW v_user_company AS
SELECT userId,c.companyId FROM `user` AS u JOIN `company` AS c
ON u.companyId=c.companyId
WHERE u.userId=1; SELECT * FROM v_user_company; ALTER VIEW v_user_company AS SELECT * FROM `user`; DROP TABLE IF EXISTS v_user_company;
八.存储过程
CREATE PROCEDURE sp_user_company(
IN inPara int,
OUT outPara int,
INOUT inOutPara int
)
BEGIN
DECLARE count int ;
SELECT COUNT(*) INTO count FROM `user`;
SET outPara=count;
SET inOutPara=count;
END; #SET @outPara=0; #可省略
#SET @inOutPara=0;
CALL sp_user_company(1,@outPara,@inOutPara);
SELECT @inOutPara;
SELECT @outPara; #MYSQL 不提供存储过程中的代码修改 DROP PROCEDURE `sp_user_company`;
九.事务
SHOW GLOBAL VARIABLES LIKE 'autocommit'; SET GLOBAL AUTOCOMMIT=0; SET GLOBAL AUTOCOMMIT=1; START TRANSACTION; ROLLBACK; COMMIT;
十.自定义函数
CREATE FUNCTION fn_user_company() RETURNS int
BEGIN
DECLARE count int ;
SELECT COUNT(*) INTO count FROM `user`;
RETURN count;
END; SELECT fn_user_company(); CREATE FUNCTION fn_user_company1(count int) RETURNS int
BEGIN
RETURN count;
END; SELECT fn_user_company1(1); SHOW CREATE FUNCTION `fn_user_company`; #函数不能内部的内容 DROP FUNCTION `fn_user_company`;
十一.游标
CREATE PROCEDURE `sp_logic`()
BEGIN
DECLARE stuId int;
DECLARE stuName varchar(20) CHARACTER SET UTF8;
DECLARE done int DEFAULT 0;
DECLARE myCursor CURSOR FOR SELECT * FROM `user`;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;
OPEN myCursor;
SET total=0;
c:LOOP
FETCH myCursor INTO stuId,stuName;
IF done=1 THEN
LEAVE c;
END IF ;
SET total =total+1;
END LOOP;
CLOSE myCursor;
SELECT total;
END;
十二.常用函数
数值型函数

字符串函数

日期和时间函数

聚合函数和流程控制函数

温故而知新——MYSQL基本操作的更多相关文章
- mysql 基本操作语句
mysql 基本操作笔记: 创建表demo:CREATE TABLE `role` ( `role_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMME ...
- css属性编写顺序+mysql基本操作+html细节(个人笔记)
css属性编写顺序: 影响文档流的属性(比如:display, position, float, clear, visibility, table-layout等) 自身盒模型的属性(比如:width ...
- 【mysql】mysql基本操作
mysql基本操作 1.mysql表复制 mysql 表结构的复制 create table t2 like t2 mysql 表数据的复制 insert into t2 select * from ...
- 数据库相关 Mysql基本操作
数据库相关 设计三范式: 第一范式: 主要强调原子性 即表的每一列(字段)包含的内容,不能再拆分.如果,某张表的列,还可以细分,则违背了数据库设计的第一范式. 第二范式: 主要强调主键,即:数据库中的 ...
- 温故而知新-mysql高级管理
温故而知新-mysql高级管理 1 mysql的一些授权信息都保存在授权表中 授权表是6个 db,user,host,tables_priv,columns_priv,procs_priv 这6个表 ...
- Mysql基本操作、C++Mysql简单应用、PythonMysql简单应用
MySql基本操作 -- 当指定名称的数据库不存在时创建它并且指定使用的字符集和排序方式 CREATE DATABASE IF NOT EXISTS db_name CHARACTER SET UTF ...
- MySQL必知必会笔记-Mysql基本操作
Mysql基本操作 mysql的基本操作包括增.删.改.查,本书中前三章简单的介绍MySQL为何物,查是mysql中非常重要的功能,4-6章展示了mysql的查(查询--select)的简单实现,my ...
- day02 MySQL基本操作
day02 MySQL基本操作 昨日内容回顾 数据库演变史 1.纯文件阶段 2.目录规范 3.单机游戏 4.联网游戏 # 数据库就是一款帮助我们管理数据的程序 软件开发架构及数据库本质 cs架构与bs ...
- MYSQL基本操作(上)
很久之前,就想做个Mysql的小结,毕竟数据库知识是软件研发的基本技能,这里话不多说,开始总结一波. 数据库基本概念 数据库为高效的存储和处理数据的介质(主要分为磁盘和内存两种),一般关系型数据库存储 ...
- MySQL(二) MySQL基本操作
数据库的基本操作 启动关闭 MySQL 服务 MySQL 安装好后,默认是当 Windows 启动.停止时,MySQL 也自动.停止.不过,用户可以使用 Windows 下的服务管理器或从命令行使用 ...
随机推荐
- C++在HotSpot VM中一种巧妙的内存管理方式
在HotSpot VM中定义了一个Relocation类及相关的子类,可以通过这些类操作不同的重定位数据,如在CodeCache中读写这些数据.这些类需要的内存很小,但是不同的类需要的内存大小又不一样 ...
- 算法修养--A*寻路算法
A*寻路算法 广度优先算法 广度优先算法搜索以广度做未优先级进行搜索. 从起点开始,首先遍历起点周围邻近的点,然后再遍历已经遍历过的点邻近的点,逐步的向外扩散,直到找到终点. 这种算法就像洪水(Flo ...
- 中山市 香山杯2023 Misc pintu
大便题目啊,跟拼图没有半毛钱关系 附件给我们4703张图片,而且给了tip:8->10,且这些图片的宽度都是一样的. 首先我们考虑将黑色图片当作0,白色图片当作1,将这些按编号顺序将这些图片转成 ...
- Go开发IDE全览:GoLand vs VSCode全面解析
关注[TechLeadCloud],分享互联网架构.云服务技术的全维度知识.作者拥有10+年互联网服务架构.AI产品研发经验.团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构 ...
- 数据结构与算法 | 深搜(DFS)与广搜(BFS)
深搜(DFS)与广搜(BFS) 在查找二叉树某个节点时,如果把二叉树所有节点理理解为解空间,待找到那个节点理解为满足特定条件的解,对此解答可以抽象描述为: 在解空间中搜索满足特定条件的解,这其实就是搜 ...
- k8s Rabbitmq安装部署
安装方式 kubectl apply -f rabbitmq.yaml -n yunda-dev-cache rabbitmq.yaml ##创建PV # 注意更换存储方式 --- apiVersio ...
- angular,vue,react三大框架选型
三大框架,本质都是基于js的web应用(前端做的都是web应用包括移动)框架,他们都是帮助我们解决问题的工具,具体用哪个,要结合具体场景. 这三者中,Angular的适用领域相对窄一些,React可以 ...
- 二叉树、平衡二叉树、红黑树、B树、B+树
几种树的主要区别: 红黑树为二叉自平衡搜索树,深度大,多用于内存排序: B树为多路(多叉)搜索树,深度低,搜索数据时磁盘IO较少,多用于索引外存数据,只支持随机访问,不支持顺序访问: B+树是对B树的 ...
- 在路上---学习篇(一)Python 数据结构和算法 (6)基于GA(遗传)算法的小案例
独白 最近了解到一种算法叫遗传算法,对其比较感兴趣,研究了一下,是模拟达尔文生物进化论的自然选择和遗传学机理的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法.遗传算法是从代表问题可 ...
- 【GIT】学习day03 | 如何生成并配置SSH公钥【外包杯】
快速笔记: 1.注册并激活码云账号 2.生成并配置SSH公钥(运行ssh -t git@gitee.com 检测SSH公钥是否配置成功) 3.创建空白的码云仓库 4.把本地项目上传到码云对应的空白仓库 ...