位置: 编程技术 - 正文

MySQL进阶SELECT语法篇

编辑:rootadmin
MySQL中SELECT语句的基本语法是: SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY] [DISTINCT|DISTINCTROW|ALL] select_list [INTO {OUTFILE|DUMPFILE} 'file_name' export_options] [FROM table_references [WHERE where_definition] [GROUP BY col_name,...] [HAVING where_definition] [ORDER BY {unsighed_integer|col_name|formura} [ASC|DESC],...] [LIMIT [offset,] rows] [PROCEDURE procedure_name]] STRAIGHT_JOIN、SQL_SMALL_RESULT、SQL_BIG_RESULT、HIGH_PRIORITY是MySQL对ANSI SQL的扩展。如果优化器以非最佳次序联结表,使用STRAIGHT_JOIN可以加快查询。 SQL_SMALL_RESULT和SQL_BIG_RESULT是一组相对的关键词。它们必须与GROUP BY、DISTINCT或DISTINCTROW一起使用。SQL_SMALL_RESULT告知优化器结果会很小,要求MySQL使用临时表存储最终的表而不是使用排序;反之,SQL_BIG_RESULT告知优化器结果会很小,要求MySQL使用排序而不是做临时表。 HIGH_PRIORITY将赋予SELECT比一个更新表的语句更高的优先级,使之可以进行一次优先的快速的查询。 以上四个关键词的使用方法的确比较晦涩。幸运的是,在绝大多数情况下,在MySQL中我们完全可以选择不使用这四个关键词。 DISTINCT、DISTINCTROW对查询返回的结果集提供了一个最基本但是很有用的过滤。那就是结果集中只含非重复行。在这里要注意的是,对关键词DISTINCT、DISTINCTROW来说,空值都是相等的,无论有多少NULL值,只选择一个。而ALL的用法就有画蛇添足之嫌了。它对结果集的产生没有任何影响。 INTO {OUTFILE|DUMPFILE} 'file_name' export_options,将结果集写入一个文件。文件在服务器主机上被创建,并且不能是已经存在的。语句中的export_options部分的语法与用在LOAD DATAINFILE语句中的FIELDS和LINES子句中的相同,我们将在MySQL进阶_LOAD DATA篇中详细讨论它。而OUTFILE与DUMPFILE的关键字的区别是:后前只写一行到文件,并没有任何列或行结束。 select list:其中可以包含一项或多项下列内容: 1、“*”,表示按照create table的顺序排列的所有列。 2、按照用户所需顺序排列的列名的清单。 3、可以使用别名取代列名,形式如下:column name as column_heading。 4、表达式(列名、常量、函数,或以算术或逐位运算符连接的列名、常量和函数的任何组合)。 5、内部函数或集合函数。 6、上述各项的任何一种组合。 FROM:决定SELECT命令中使用哪些表。一般都要求有此项,除非select_list中不含列名(例如,只有常量、算术表达式等)。如果表项中有多个表,用逗号将之分开。在关键词FROM后面的表的顺序不影响结果。 表名可以给出相关别名,以便使表达清晰。这里的语法是tbl_name [AS] alias_name。例如: select t1.name,t2.salary from employee as t1,info as t2 where t1.name=t2.name与select t1.name,t2.salary from employee t1,info t2 where t1.name=t2.name是完全等价的。 所有对该表的其他引用,例如在where子句和having子句中,都要用别名,别名不能以数字开头。 where子句设置了搜索条件,它在insert,update,delete语句中的应用方法也与在select语句中的应用方法完全相同。搜索条件紧跟在关键词where的后面。如果用户要在语句中使用多个搜索条件,则可用and或or连接。搜索条件的基本语法是[not] expression comparison_operator expression;[not] expression [not] like “match_string”;[not] expression is [not] null;[not] expression [not] between expression and expression;[not] column_name join_operator column_name;[not] boolean_expression。 and:用来联结两个条件,并在两个条件都是TRUE的时候返回结果。当在同一语句中使用多个逻辑运算符时,and运算符总是最优先,除非用户用括号改变了运算顺序。 or:用来联结两个条件,当两个条件中有任一条件是TRUE的时候返回结果。当在同一语句中使用多个逻辑运算符时,运算符or通常在运算符and之后进行运算。当然用户可以使用括号改变运算的顺序。 between:用来标识范围下限的关键词,and后面跟范围上限的值。范围where @val between x and y包含首尾值。如果between后面指定的第一个值大于第二个值,则该查询不返回任何行。 column_name:在比较中使用的列名。在会产生歧义时,一定要指明列所在的表名。 comparison_operator:比较运算符。见下表: 符号 意义 = 等于 > 大于 < 小于 >= 大于等于 <= 小于等于 != 不等于 <> 不等于 在比较char,varchar型数据时,“<”的意思是更接近字母表头部,“>”代表更接近字母表尾部。一般来说,小写字母大于大写字母,大写字母大于数字,但是这可能依赖于服务器上操作系统的比较顺序。 在比较时,末尾的空格是被忽略的。例如,“Dirk”等于“Dirk ”。 在比较日期时,“<”表示早于,“>”表示晚于。 在使用比较运算符比较character和datetime数据时,需用引号将所有数据引起来。 expression:可能是列名、常数、函数或者是列名或常数的任意组合,以及以算术运算符或逐位运算符连接的函数。算术运算符如下表所示: 符号 意义 + 加号 - 减号 * 乘号 / 除号 is null:在搜索一个NULL值时使用。 like:关键词,对char、varchar和datetime(不包括秒和毫秒)可以使用like,在MySQL中like也可以用在数字的表达式上。 当用户在搜索datetime型数据时,最好是使用关键词like,因为完整的datetime记录包含各种各样的日期组件。例如用户在列arrival_time中加入一个值“9:”,而子句where arrival_time=“9:”却没有发现它,因为MySQL把录入的数据转换成了“Jan 1, 9:AM”。然而子句where arrival_time like“%9:%”就能找到它。 boolean_expression:返回“true”或“false”值的表达式。 match_string:由字符和通配符组成的串,用单引号或双引号引起来,是匹配模式。通配符如下表所示: 符号 意义 % 0或多个字符的字符串 _ 任何一单个字符 not:否定任何逻辑表达式,或是关键词,如like,null,between等。 group by和having子句在select语句中使用,可以将表划分成组并返回匹配having子句条件的组。 语法:select语句开头 group by [all] aggregate_free_expression [,aggregate_free_expression]* [having search_conditions] select语句结尾 group by:指定表将划分的组群,如果在select表项中包含集合函数,则为各组计算一个总计值。这些总计值的结果以新的列显示,而不是新的行。在having子句中用户可以引用这些新的总计列。在group by之前的select_list中可以使用avg、count、max、min和sum等集合函数。表可以被任意列的组合分组。 all:在结果中包含所有组群的Transact-SQL扩展,这里的所有组群甚至包括那些被where子句所排除的组群。如果同时使用having子句,将对all的意义进行否定。 aggregate_free_expression:不包含集合函数的表达式,Transact-SQL扩展允许在用列名称分组的同时,用无集合函数的表达式分组。 having:为group by子句设置条件,类似于where为select语句设置条件的方法。having的查找条件可以包括集合函数表达式。除此之外,它的查找条件与where查找条件相同。 order by:按列排列结果。对select输出的列可以用列名、列别名或列位置来引用。例如:select id as myid,name as myname from mytable group by id、select id as myid,name as myname from mytable group by myid、select id as myid,name as myname from mytable group by 1这三句是完全等价的。当然,我们不赞成用第三种用法,这将给程序的可读性带来不好的影响。 为了以降序排列,把DESC关键词加到order by子句中你要排序的列名前。缺省是升序,你也可以用ASC关键词明确指定。 limit 子句:用来限制select语句返回的行数。limit取1个或2个数字参数,如果给定2个参数,第一个指定要返回的第一行的偏移量,第二个指定返回行的最大数目。初始行的偏移量是0(不是1)。如果给定一个参数,它指出偏移量为0的返回行的最大数目。也就是说limit 5和limit 0,5完全等价。 至于procedure关键词的含义,我也没搞得太清楚,好象是对存储过程的支持,而MySQL本身不支持存储过程,看来是为了将来扩充的需要而保留的吧。

推荐整理分享MySQL进阶SELECT语法篇,希望有所帮助,仅作参考,欢迎阅读内容。

MySQL进阶SELECT语法篇

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

MySQL里面的子查询实例 一,子选择基本用法1,子选择的定义子迭择允许把一个查询嵌套在另一个查询当中。比如说:一个考试记分项目把考试事件分为考试(T)和测验(Q)

mysql的日期和时间函数大全第1/2页 mysqlSELECTsomethingFROMtbl_nameWHERETO_DAYS(NOW())-TO_DAYS(date_col)=;DAYOFWEEK(date)返回date的星期索引(1=Sunday,2=Monday,...7=Saturday)。索引值符合ODBC的标准。mysqlSELECTDAYOFWEEK

MySQL的数据类型和建库策略分析详解 一、数字类型。数字类型按照我的分类方法分为三类:整数类、小数类和数字类。我所谓的数字类,就是指DECIMAL和NUMERIC,它们是同一种类型。它严格

标签: MySQL进阶SELECT语法篇

本文链接地址:https://www.jiuchutong.com/biancheng/319881.html 转载请保留说明!

上一篇:MySQL服务器的启动和关闭(mysql服务器怎么启动)

下一篇:MySQL里面的子查询实例(mysql 子查询)

  • 牵引车和挂车都要购买交强险吗
  • 工资表多扣个税怎么做账
  • 货币资金包括应收票据和应收账款吗
  • 预付账款只有部分开了发票怎么入账
  • 发票开具税收分类是什么意思?
  • 商品混凝土的增值税费率
  • 职工福利费包括五险一金吗
  • 汇总会计报表和合并会计报表均是
  • 团建费用是什么意思
  • 个税申报密码是什么意思
  • 1697509419
  • 不同税率的发票可以合并入账吗
  • 怎样将u盘制作成电脑系统启动盘?
  • 建筑业销项税和进项税计算
  • 报考中级会计的工作证明
  • unix和linux适用于
  • 个人销售自己使用过的物品免征增值税
  • php数组查找
  • php快递查询系统
  • thinkphp5开发教程
  • 跨境服务免征增值税申报怎么填
  • 合并财务报表抵消损益怎么理解
  • php __callstatic
  • print-js
  • 个体工商户加盟咖啡店
  • h5调用海康摄像头
  • php获取访问用户的ip
  • PHP:imagefontwidth()的用法_GD库图像处理函数
  • 企业所得税如何更正申报
  • 蓝湖怎么用的
  • 原生js获取元素高度
  • 一站式自动化测试平台如何滑动
  • vue.js简介
  • 建设工程施工合
  • 企业确认坏账损失领导如何回复
  • 小规模纳税人购入货物收到增值税专用发票
  • 员工工资费用
  • 公司名下商品房过户给公司需要交过户费
  • 企业转让商品取得的税收
  • 销售农产品是否交消费税
  • 法人股东 分红
  • 利息收入怎么入账
  • 报销替票的风险是什么
  • 对股息红利的征税
  • 财政补贴收入要交增值税税率
  • 小微企业是怎样自己认定的呢
  • 城市维护建设税的计税依据
  • 劳务分包预缴税款计算公式
  • 电子商务会计科目有哪些
  • 买车抵扣增值税超销项怎么算
  • 清理固定资产的税费
  • 企业内部之间借款利息可以税前扣除吗
  • 产品质量的保证需要哪几方面的支持
  • 查账补缴的税的账怎么做
  • 理财产品产生的收益会成为本金吗为什么
  • 目前哪些费用不能抵扣
  • 会计一般采用什么科目
  • Windows 10 与 MySQL 5.5 安装使用及免安装使用详细教程(图文)
  • mysql字符集设置命令
  • mac小技巧
  • win1020h2正式版
  • xp电脑繁体系统改简体
  • 怎么才能把win7变win10
  • Win7旗舰版系统镜像文件
  • 电脑ie8浏览器
  • linux文件一般放哪里
  • win8分屏快捷键
  • 学习的引子
  • 怎么重置mysql的密码
  • dos命令中运行文件的命令
  • python appium 微信
  • nodejs mocha
  • javascript中用于声明变量的关键字
  • unity3ds
  • 深度定制Python的Flask框架开发环境的一些技巧总结
  • 税务u盘是干嘛的
  • 应交税费应交增值税已交税金是什么意思
  • 税务机关对核准类减免税的审核
  • 厂房房产税2021年税率
  • 近亲房屋赠与免税费
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设