MySQl数据库必知必会的加强版sql语句

本文给大家分享了一篇关于mysql数据库必会sql语句加强版内容,非常不错,具有参考借鉴价值,需要的朋友参考下吧

这一篇属于加强版,问题和sql语句如下。

创建users表,设置id,name,gender,sal字段,其中id为主键 

drop table if exists users; create table if not exists users(   id int(5) primary key auto_increment,   name varchar(10) unique not null,     gender varchar(1) not null,   sal int(5) not null ); insert into users(name,gender,sal) values('AA','男',1000); insert into users(name,gender,sal) values('BB','女',1200);

————————————————————————————– 

一对一:AA的身份号是多少 

drop table if exists users; create table if not exists users(   id int(5) primary key auto_increment,   name varchar(10) unique not null,     gender varchar(1) not null,   sal int(5) not null ); insert into users(name,gender,sal) values('AA','男',1000); insert into users(name,gender,sal) values('BB','女',1200); drop table if exists cards; create table if not exists cards(   id int(5) primary key auto_increment,   num int(3) not null unique,   loc varchar(10) not null,   uid int(5) not null unique,   constraint uid_fk foreign key(uid) references users(id) ); insert into cards(num,loc,uid) values(111,'北京',1); insert into cards(num,loc,uid) values(222,'上海',2);

【注:inner join表示内连接】 

select u.name "姓名",c.num "身份证号" from users u inner join cards c on u.id = c.uid where u.name = 'AA'; -- select u.name "姓名",c.num "身份证号" from users u inner join cards c on u.id = c.uid where name = 'AA';

——————————————— 

一对多:查询”开发部”有哪些员工 

创建groups表 

drop table if exists groups; create table if not exists groups(   id int(5) primary key auto_increment,   name varchar(10) not null ); insert into groups(name) values('开发部'); insert into groups(name) values('销售部');

创建emps表 

drop table if exists emps; create table if not exists emps(   id int(5) primary key auto_increment,   name varchar(10) not null,   gid int(5) not null,   constraint gid_fk foreign key(gid) references groups(id) ); insert into emps(name,gid) values('哈哈',1); insert into emps(name,gid) values('呵呵',1); insert into emps(name,gid) values('嘻嘻',2); insert into emps(name,gid) values('笨笨',2);

查询”开发部”有哪些员工 

select g.name "部门",e.name "员工" from groups g inner join emps e on g.id = e.gid where g.name = '开发部'; -- select g.name "部门",e.name "员工" from groups g inner join emps e on g.id = e.gid where g.name = '开发部';

—————————————————— 

多对多:查询”赵”教过哪些学生 

创建students表 

drop table if exists students; create table if not exists students(   id int(5) primary key auto_increment,   name varchar(10) not null ); insert into students(name) values('哈哈'); insert into students(name) values('嘻嘻');

创建teachers表 

drop table if exists teachers; create table if not exists teachers(   id int(5) primary key auto_increment,   name varchar(10) not null ); insert into teachers(name) values('赵'); insert into teachers(name) values('刘');

创建middles表   primary key(sid,tid)  表示联合主键,这两个字段的整体要唯一 

drop table if exists middles; create table if not exists middles(   sid int(5),   constraint sid_fk foreign key(sid) references students(id),   tid int(5),   constraint tid_fk foreign key(tid) references teachers(id),   primary key(sid,tid)  ); insert into middles(sid,tid) values(1,1); insert into middles(sid,tid) values(1,2); insert into middles(sid,tid) values(2,1); insert into middles(sid,tid) values(2,2);

查询”赵”教过哪些学生 

select t.name "老师",s.name "学生" from students s inner join middles m inner join teachers t on (s.id=m.sid) and (m.tid=t.id) where t.name = '赵'; -- select t.name "老师",s.name "学生" from students s inner join middles m inner join teachers t  on (s.id=m.sid) and (t.id=m.tid) where t.name = "赵";

——————————————————————————————————– 

将5000元(含)以上的员工标识为”高薪”,否则标识为”起薪” 

将薪水为NULL的员工标识为”无薪” 

将5000元(含)以上的员工标识为”高薪”,否则标识为”起薪” 

将7000元的员工标识为”高薪”,6000元的员工标识为”中薪”,5000元则标识为”起薪”,否则标识为”试用薪”

——————————————————————————————————— 

内连接(等值连接):查询客户姓名,订单编号,订单价格 

【注:customers c inner join orders o使用了别名,以后o就代表orders】 

select c.name "客户姓名",o.isbn "订单编号",o.price "订单价格" from customers c inner join orders o on c.id = o.customers_id; -- select c.name "客户姓名",o.isbn "订单编号",o.price "订单价格" from customers c inner join orsers o on c.id = o.customers_id;

on+两张表连接的条件.一张表的主键,一张表的外键 

内连接:只能查询出二张表中根据连接条件都存在的记录,有点类似于数学中交集 

—————————————————- 

外连接:按客户分组,查询每个客户的姓名和订单数 

外连接:既可以根据连接条件查询出二张表中都存在的记录,也能根据一方,强行将另一方就算不满兄条件的记录也能查询出来 

外连接可以细分为:

右外连接 : 以右侧为参照,right outer join表示 select c.name,count(o.isbn) from orders o right outer join customers c on c.id = o.customers_id group by c.name;

left outer join表示左边的内容都会显现出来,例如customers c left out join 表示会把customers中的某列所有内容都找出来  

—————————————————— 
自连接:求出AA的老板是EE。把自己想象成两张表。左右各一张 

select users.ename,bosss.ename from emps users inner join emps bosss on users.mgr = bosss.empno; select users.ename,bosss.ename from emps users left outer join emps bosss on users.mgr = bosss.empno;

———————————————————————————————– 
演示MySQL中的函数(查询手册)  

日期时间函数: 

select addtime('2016-8-7 23:23:23','1:1:1');  时间相加 select current_date(); select current_time(); select now(); select year( now() ); select month( now() ); select day( now() ); select datediff('2016-12-31',now());

字符串函数:

select charset('哈哈'); select concat('你好','哈哈','吗'); select instr('www.baidu.com','baidu'); select substring('www.baidu.com',5,3);

数学函数: 

select bin(10); select floor(3.14);//比3.14小的最大整数---正3 select floor(-3.14);//比-3.14小的最大整数---负4 select ceiling(3.14);//比3.14大的最小整数---正4 select ceiling(-3.14);//比-3.14大的最小整数---负3,一定是整数值 select format(3.1415926,3);保留小数点后3位,四舍五入 select mod(10,3);//取余数 select rand();//

加密函数: 

select mysql0(‘123456’); 

返回32位16进制数 e10adc3949ba59abbe56e057f20f883e  

演示MySQL中mysql1语句 

use json; drop table if exists users; create table if not exists users(   id int(5) primary key auto_increment,   name varchar(10) not null unique,   sal int(5) ); insert into users(name,sal) values('哈哈',3000); insert into users(name,sal) values('呵呵',4000); insert into users(name,sal) values('嘻嘻',5000); insert into users(name,sal) values('笨笨',6000); insert into users(name,sal) values('明明',7000); insert into users(name,sal) values('丝丝',8000); insert into users(name,sal) values('君君',9000); insert into users(name,sal) values('赵赵',10000); insert into users(name,sal) values('无名',NULL);

将5000元(含)以上的员工标识为”高薪”,否则标识为”起薪”

select name "姓名",sal "薪水",     if(sal>=5000,"高薪","起薪") "描述" from users;

将薪水为NULL的员工标识为”无薪”

select name "姓名",ifnull(sal,"无薪") "薪水" from users;

将5000元(含)以上的员工标识为”高薪”,否则标识为”起薪”

select name "姓名",sal "薪水",     case when sal>=5000 then "高薪"     else "起薪" end "描述" from users;

将7000元的员工标识为”高薪”,6000元的员工标识为”中薪”,5000元则标识为”起薪”,否则标识为”试用薪”

select name "姓名",sal "薪水",     case sal       when 3000 then "低薪"       when 4000 then "起薪"       when 5000 then "试用薪"       when 6000 then "中薪"       when 7000 then "较好薪"       when 8000 then "不错薪"       when 9000 then "高薪"       else "重薪"     end "描述" from users;

以上就是MySQl数据库必知必会的加强版sql语句的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/415588.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 01:04:14
下一篇 2025年11月7日 01:05:39

相关推荐

  • JavaScript中的标签模板字面量(Tagged Templates)有哪些高级用法?

    标签模板通过自定义函数实现复杂逻辑,如html函数转义防止XSS,css函数生成唯一类名封装样式,结合哈希值隔离组件样式,确保安全与模块化。 标签模板字面量不只是字符串拼接工具,它能结合函数实现更复杂的逻辑处理。通过自定义标签函数,你可以解析模板中的表达式和静态部分,从而实现如国际化、样式封装、安全…

    2025年12月20日
    000
  • 如何用Node.js构建高并发的IO密集型应用?

    Node.js适合高并发IO密集型应用因其事件驱动与非阻塞IO特性,应使用异步API如fs.promises、axios及mysql2/promise避免阻塞;通过cluster模块利用多核CPU提升吞吐量,并用PM2管理进程;需控制并发数防止资源耗尽,采用p-limit或连接池限制;结合Redis…

    2025年12月20日
    000
  • React 应用管理员面板构建:从本地 JSON 到生产级数据管理

    本文旨在指导React应用开发者如何为电商网站等应用构建管理员面板,以实现数据(如商品卡片)的增删改查。文章将探讨从本地JSON文件管理的局限性,到利用浏览器端文件下载模拟数据更新的临时方案,再到后端服务和无头CMS(如Strapi)等生产级解决方案,帮助开发者选择最适合其项目需求的数据管理策略。 …

    2025年12月20日
    000
  • Snowflake响应转换器中动态迭代的实现:UDF与存储过程的结合策略

    本文探讨了如何在Snowflake响应转换器中动态获取数据(如表行数)以控制迭代,解决了直接在转换器中调用存储过程的限制。核心策略是将原存储过程的逻辑重构为JavaScript用户定义函数(UDF),并在调用时将其结果作为参数传递给响应转换器,从而实现灵活的数据处理和迭代控制。 挑战:在Snowfl…

    2025年12月20日
    000
  • 构建React应用管理后台:从本地JSON到Headless CMS的实践指南

    本文探讨了为React应用创建管理后台的多种方法,特别针对从本地JSON文件管理数据到实现可编辑、删除和添加内容的场景。我们将深入分析直接操作本地文件的局限性,介绍后端服务的重要性,并重点推荐使用Strapi等无头CMS作为高效、可扩展的解决方案,帮助开发者轻松构建功能完善的管理界面。 React应…

    2025年12月20日
    000
  • React应用管理面板构建指南:从本地JSON到无头CMS的实践策略

    为React应用构建管理员面板,以高效管理数据是常见需求。本文将探讨从本地JSON文件管理的局限性出发,逐步介绍客户端下载替换方案、自定义后端解决方案,并重点推荐使用Strapi等无头CMS作为现代、高效且可扩展的数据管理平台,帮助开发者为React应用快速搭建功能完善的管理界面。 1. 理解本地J…

    2025年12月20日
    000
  • 为React应用构建管理员面板:从本地JSON到无头CMS的数据管理策略

    本文探讨了为React应用创建管理员面板以管理数据(如商品信息)的多种策略。从简单的客户端本地JSON文件编辑,到传统后端集成,再到现代无头CMS(如Strapi)的运用,文章详细分析了各种方案的优缺点,并提供了实现思路和代码示例,旨在帮助开发者选择最适合其项目需求的数据管理解决方案。 引言:从静态…

    2025年12月20日
    000
  • 优化Snowflake响应转换器:通过UDF动态获取表行数

    本教程旨在解决Snowflake响应转换器中动态获取表行数的需求。通过将原有的存储过程重构为用户定义函数(UDF),并将其结果作为参数传递给响应转换器,我们能够实现迭代逻辑的动态化,从而提高数据处理的灵活性和效率,避免直接调用存储过程的限制。 在snowflake中,外部函数(external fu…

    2025年12月20日
    000
  • Snowflake响应转换器:实现动态循环与外部数据集成

    本教程详细阐述了如何在Snowflake的JavaScript响应转换器(Response Translator)中实现动态循环控制。通过将获取外部数据(如表行数)的逻辑封装为独立的JavaScript标量函数,并在调用响应转换器时将其结果作为参数传入,有效规避了在转换器内部直接执行数据库查询的限制…

    2025年12月20日
    000
  • JavaScript中的标签模板字面量有哪些高级用法?

    标签模板通过自定义函数控制解析逻辑,可实现HTML转义、国际化、CSS注入和DSL构建。1. safeHtml函数对用户输入转义,防止XSS攻击;2. t函数结合语言包实现多语言支持,结构清晰易维护;3. css函数动态生成样式并注入head,避免全局污染;4. query函数构造SQL语句,提升代…

    2025年12月20日 好文分享
    000
  • 解决循环中重复ID与AJAX成功消息定位问题的教程

    在Web开发中,当使用循环动态生成HTML元素时,为每个元素分配唯一的ID至关重要,尤其是在结合JavaScript和AJAX进行交互时。本文将深入探讨如何避免在循环中重复使用ID导致的AJAX成功消息错位问题,并提供正确的事件绑定和元素定位策略,确保每次操作都能准确更新对应的UI部分,提升用户体验…

    2025年12月20日
    000
  • PHP循环中动态表单的AJAX提交与局部反馈优化

    本文旨在解决PHP while 循环中动态生成表单元素时,AJAX提交后成功消息显示错位的问题。核心在于纠正jQuery事件绑定方式,确保ID唯一性或利用类选择器及DOM遍历,并通过正确管理JavaScript this 上下文,实现精准的局部反馈更新。 理解问题根源 在php等后端语言的 whil…

    2025年12月20日
    000
  • 如何在循环中处理动态生成元素的唯一标识与AJAX回调

    在Web开发中,当使用循环动态生成HTML元素时,重复的ID属性会导致JavaScript事件绑定和AJAX回调的目标定位错误。本文将详细阐述如何避免此类问题,通过使用唯一的标识符、正确的事件绑定方式以及AJAX的context选项,确保每个动态生成元素的操作都能准确地更新其对应的UI部分。 1. …

    2025年12月20日
    000
  • PHP循环中动态表单的AJAX交互与成功消息精确定位

    本文旨在解决在PHP while 循环中生成多个相似表单时,AJAX成功消息无法精确定位到用户操作表单的问题。通过修正jQuery事件绑定语法,并利用AJAX的 context 选项或局部变量捕获 this 上下文,结合DOM遍历方法,实现对特定表单的成功消息进行准确更新,确保用户体验的一致性与功能…

    2025年12月20日
    000
  • 如何用JavaScript实现一个支持版本迁移的数据库架构?

    在JavaScript项目中实现一个支持版本迁移的数据库架构,核心在于将数据库结构的变化视为代码版本的一部分,通过一系列可控、可追溯的脚本来管理这些变更。无论是浏览器端的IndexedDB还是Node.js环境下的关系型数据库,我们都需要一个机制来检测当前数据库的状态,并按序应用所需的升级脚本,确保…

    2025年12月20日
    000
  • 如何用JavaScript实现一个支持事务的数据操作层?

    答案:通过IndexedDB和数据库事务封装实现数据操作的原子性。前端利用IndexedDB的异步事务机制,确保多个操作要么全部成功,要么全部回滚;后端借助连接池和withTransaction方法,结合Repository模式,在同一事务上下文中协调多步操作,保证数据一致性与系统可靠性。 如何用J…

    2025年12月20日
    000
  • 如何利用Promise和async/await处理异步操作,以及它们在实际项目中的应用场景有哪些?

    Promise和async/await通过简化异步编程提高代码可读性与维护性,适用于处理依赖关系复杂的异步请求。使用Promise.all并行处理多个独立请求,Promise.race处理首个完成的请求,async/await结合try…catch管理异常,避免阻塞与并发滥用,广泛应用于…

    2025年12月20日
    000
  • Node.js中处理MySQL异步查询结果:避免undefined错误

    针对Node.js应用中MySQL异步查询返回undefined的常见问题,本教程深入探讨了JavaScript异步编程机制。我们将分析回调函数内部return语句的局限性,并通过重构代码演示如何利用回调函数、Promise以及async/await语法正确地从异步数据库操作中获取并处理数据,确保数…

    2025年12月20日
    000
  • Node.js异步数据库查询结果undefined问题解析与解决方案

    本文深入探讨Node.js中异步数据库查询返回undefined的常见问题。通过分析异步操作的执行机制和回调函数的返回值作用域,详细解释了为何在异步上下文中无法直接获取数据。文章提供了使用回调函数和更推荐的Promise/async-await模式来正确处理异步数据流的解决方案,并辅以代码示例和最佳…

    2025年12月20日
    000
  • Node.js数据库查询数据undefined问题深度解析与异步处理实践

    本教程深入剖析Node.js中数据库异步查询返回undefined的常见问题。当在回调函数中尝试返回值时,外部函数无法同步获取数据是核心原因。文章将详细解释异步操作的本质,并提供基于回调函数、Promise以及async/await等多种解决方案,旨在帮助开发者正确地从异步数据库操作中获取并处理数据…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信