A. 快速掌握MySQL数据库中SELECT语句[1]
本文针对 MySQL 数据库 中的SELECT语句快速精细掌握
MySQL中SELECT语句的基本语法是
Word WRAP: break word bgColor=#f f f > 以下是引用片段 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 procere_name]]
从这个基本语法可以看出 最简单的SELECT语句是SELECT select_list 实际上利用这个最简单的SELECT语句 你也可以完成许多你期待的功能 首先你能利用它进行MySQL所支持的任何运算 例如 SELECT + 它将返回 ;其次 你也能利用它给变量赋值 而在 PHP 中 运用SELECT语句的这种功能 你就可以自由地运用MySQL的函数为PHP程序进行各种运算 并赋值给变量 在很多的时候 你会发现MySQL拥丛派运有许多比PHP更为功能强大的函数
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 其中可以包含一项或多项下列内容
* 表示按照create table的顺序排列的所有列
按照用户所需顺序排列的列名的清单
可以使用别名取代列名 形式如下 column name as column_heading
表达式(列名 常量 函数 或以算术或逐位运算符连接的列名 常量和函数的任何组合)
内部函数或集合函数
上述各项的任何一种组合
FROM 决定SELECT命令中使用哪些表 一般都要求有此项 除非select_list中不含列名(例如 只有常量 算术表达式等) 如果表项中有多个表 用逗号将之分开 在关键词FROM后面的表的顺序不影响结果
表名可以给出相关别名 以便使表达清晰 这里的语法是tbl_name [AS] alias_name 例如
select t name t salary from employee as t info as t where t name=t name与select t name t salary from employee t info t where t name=t name是完全等价的
所有对该表的其他引用 例如在where子句和having子句中 都要用别名 别名不能以数字开头
lishixin/Article/program/MySQL/201311/29616
B. mysql 中怎么用select * from TABLES
select 是mysql的查询语句,使用前须指定使用的是哪个数据库,
查看有哪些数据库:
C. MySQL笔记1select基础
查询语句:select 语句
三种能力:投影、选择、连接
投影:在一张二维表中根据所需要的条件选出所需要的列
选择:在二维表中根据所需的条件选择合适的行
连接:从一张或者多张表中获取所需要的行,并且把这个行结合在一起的查询
SQL语句大小写不敏感。
select语句是可以计算的
算术表达式和判启运算符优先级
举例:select ename,sal 12*sal+100 from emp
计算出年薪+100块
NULL值是不可用,且未分配的,未知并且不适用的值,可以当成是保留值
AS其实可以省略
例如:select ename as name,sal salary from emp;
查询出的字段会自动换成别名
例子:select ename "Name",sal*12 "Annual Salary" from emp;
级联操作是将列或字符串和其他列串联,由两条竖线(||)表示
select ename,job,ename || job as "Employees" from emp;
可以看出Employees就将ENAME和JOB进行结合的一个操作
在select句子中适用DISTINCT 关键字消除重复行
select distinct deptnp from emp;
限制选择的行:
where关键字
如果where后面查的数据是字符串类型或者日期类型的要加''号
#######比较条件
举几个例子:
select ename,job,sal,deptno from emp where sal between 5000 and 10000;
这个是包含了5000和10000的
in的表达:
select empno,ename,mgr,deptno from emp where mgr in (7788,7782,7000);
只要mgr有括号里面的值都显示出来。
通配符:%通配的是多个字符,_通配的是一个字符
IS NULL是查询某个字段为空的显示出来
and、or、not
例子:
查如冲团询sal>=2000和job的内容是包括MAN字符串的,当同时满足两个条件时候才返回结果。
and就是两边同时为真,or的话是有一边为真就行,not就是不等于
ASC 升序,默认升序
DESC 降序
例子:
将deptno中进行升序渣橘排列,排列出来后,在将sal进行降序排列。
单行函数:就是对单行数据进行处理的函数,只针对这一条数据得出一个结果
函数工作的过程
ROUND(45.926,2)是将45.926这个数字的小数点后两位进行四舍五入操作得到45.93
TRUNC(45.926,2) 是将45.926这个数字的小数点后两位后面的进行丢掉。
返回当前系统日期
经常是不同类型之间的转换
TO_CHAR就是将日期型数字型转换成字符型
例子:
数字型的转换
把字符转换成数字:
把字符转换成日期:
什么是分组函数?
另外的名字叫多行函数,针对于多行数据进行一个汇总处理的一类函数,最后会得到一个汇总的结果。
例子:
其实就是对一系列数据找最大值
基本格式:select group_function(column),... from table [where condition];
首先对一个数据进行分类汇总把每一组的数据单独的拿出来。就是对每一列数据的相同数据进行一个分组,然后在将分组后的结果再去执行select后面跟的一个分组函数的操作。
例子:
那下面这样的怎么操作呢?
其实就是对分组以后的结果再次进行一个限制筛选
where和Having的区别?
where是针对于整体的一个查询结果
Having是针对于分组后的查询结果的一个条件限制,它是不能单独存在的,它只能够在group by后面
下面是它的表达式:
显示部门的最大平均薪水是多少
select max(avg(sal))
是这样的一个嵌套
当我们查的数据存在于多个表的时候就需要多表查询
下面是用到的表
一个是EMP的职员表、一个是DEPT的部分表
表连接的三种方式:
从总类上来看:自连接、等值连接、外连接(又可以分为三类:左连接、右连接、全连接)
自连接:一个表自己与自己建立连接成为自连接或自身连接。
在查询的时候多表,这两张表是同一张表,所以在查询前我们需要对这个表进行一个别名的重命名。
举例:查询出员工编号、名字及其经理名字
MGR对应的是经理的ID号,这个对应的就是另一张经理表中的名字
表示比较连接列的值显示出最终的一个结果,其查询结果中列出被连接表中的所有列,包括其中的重复列。
查询员工的姓名 工作 部门号 部门名称
左连接就是返回左边的匹配行,不考虑右边的表是否有相应的行
(+)的意思就是dept是个匹配表,左边是一个基础表,基础表优先,如果右边这个表找不到对应的值去匹配,会自动填空
右连接就是返回右边的匹配行,不考虑左边的表是否有相应的行,如果没有会自动填空
左表右表都不做限制,所有的记录都显示,不足的地方用null填充
FULL JOIN表示emp和dept做一个全连接
ON表示触发条件 。
D. MySQL 之 SELECT FOR UPDATE
FOR UPDATE 是一种行级锁,又叫排它锁。仅适用于 InnoDB ,并且必须开启事务,在 BEGIN 与 COMMIT 之间才生效。
开启两个 MySQL 命令窗口
当 命前者令窗口1 执行完 SELECT ... FOR UPDATE 后(此时事务还未结扒悔旦束), 命令窗口2 执行 SELECT ... FOR UPDATE 语句时将会阻塞在那,直到 命令窗口1 中的事务结束(执行完 COMMIT )。
其中一个使用场景是用于修改订单状态,修改订单状态往往需要两个步骤:
当有两个任务同时请求时,有可能出现如下情况:
其中,任务B将订单状态改为3的前提是订单状态为1,但是上述情况下任务B修改订单时订单状态已变成2了,春扰并不符合预期,通过 SELECT ... FRO UPDATE 就可以解决上述问题。
E. 查询mysql数据库中所有表名
使用select命令,可以查询所有表名
写法如下:
selecttable_namefrominformation_schema.tableswheretable_schema='当前数据库'
(5)mysqlselect命令扩展阅读
其它用法
1、使用SHOW语句找出在服务器上当前存在什么数据库:
mysql> SHOW DATABASES;
2、创建一个数据库MYSQLDATA
mysql> CREATE DATABASE MYSQLDATA;
3、选择你所创建的数据库
mysql> USE MYSQLDATA; (按回车键出现Database changed 时说明操作成功!)
4、查看现在的数据库中存在什么表
mysql> SHOW TABLES;
5、创建一个数据库表
mysql> CREATE TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));
6、显示表的结构:
mysql> DESCRIBE MYTABLE;
7、往表中加入记录
mysql> insert into MYTABLE values (”hyq”,”M”);
8、用文本方式将数据装入数据库表中(例如D:/mysql.txt)
mysql> LOAD DATA LOCAL INFILE “D:/mysql.txt” INTO TABLE MYTABLE;
9、导入.sql文件命令(例如D:/mysql.sql)
mysql>use database;
mysql>source d:/mysql.sql;
F. MYSQL的select语句
语法:select 字段名 from 表名 where 条件如果你想要段喊显示多个字段的话: select 字段名,字段空丛名,.....,字段名 from 表名 where 条件你斗燃樱问的问题写法应该是:select username from user where username='$username'
G. MYSQL列中的数据以逗号隔开,如何查询
MYSQL列中的数据查询命令:
SELECT *
FROMtask_detatils
WHERE FIND_IN_SET( ‘1’, responsible_user)
命令的含义:将含有1的responsible_user列数据全部搜索出来。
采用的是find函数:查找一定范围内元素的个数。查找[first,last)范围内,与物慧toval等价的第一个元素,返回一个迭代器。如果没有这个元素,将返回last。
(7)mysqlselect命令扩展阅读:
其他的查询命令:
在命令后键入搜索的模式,再键入要搜索的文件。其中,文件名列表中也可以使用特殊字符,如“*”等,用来生成文件名列表。
如果想在搜索的模式中包含有空格的字符串,可以用单引号把要搜索的模式括起来,用来表明搜索的模式是由包含空格的字符串组成。
否则,Shell将把空格认为是命令行参数的定界符,而grep命令将把搜索模式中的单词解释为文件名列表中的一部分。在下面的例子中,grep命令在文件example中搜索模式“text file”。
用户可以在命令行知渣上用Shell特殊字符来生成将要搜索的文件名列表。在下面的例搭蚂悄子中,特殊字符“*”用来生成一个文件名列表,该列表包含当前目录下所有的文件。该命令将搜索出当前目录下所有文件中与模式匹配的行。
H. select@i:=0是什么意思
从MySQL数据库获取数据的命饥枝令变量的自增为0。SELECT命令用于从MySQL数据库获液肢改取数据,select@i:=0就是从MySQL数据库获取数据的命令变量的自增闹判为0。MySQL是一个关系型数据库管理系统,由瑞典MySQLAB公司开发,属于Oracle旗下产品。
I. mysql常用命令都有哪些
1.导出整个数据库
mysqlmp-u用户名-p–default-character-set=latin1数据库名》导出的文件名(数据库默认编码是latin1)23mysqlmp-uwcnc-psmgp_apps_wcnc》wcnc.sql
2.导出一个表
mysqlmp-u用户名-p数据库名表名》导出的文件名23mysqlmp-uwcnc-psmgp_apps_wcncusers》wcnc_users.sql
3.导出一个数据库结构
mysqlmp-uwcnc-p-d–add-drop-tablesmgp_apps_wcnc》d:wcnc_db.sql23-d没有数据–add-drop-table在每个create语句之前增加一个droptable
4.导入数据库
A:常用source命令23进入mysql数据库控制台,45如mysql-uroot-p67mysql》use数据库89然后使用source命令,后面参数为脚本文件(如这里用到的.sql)1011mysql》sourcewcnc_db.sql1213B:使用mysqlmp命令1415mysqlmp-uusername-pdbname《filename.sql1617C:使用mysql命令1819mysql-uusername-p-Ddbname《filename.sql启动与退出
1、进入MySQL:启动MySQLCommandLineClient(MySQL的DOS界面),直接输入安装时的密码即可。此时的提示符是:mysql》
2、退出MySQL:quit或exit
5.创建数据库
命令:createdatabase《数据库名》
例如:建立一个名为xhkdb的数据库
mysql》createdatabasexhkdb;
6.显示所有的数据库
命令:showdatabases(注意:最后有个s)
mysql》showdatabases;
7.删除数据库
命令:dropdatabase《数据库名》
8.连接数据库
命令:use《数据库名》
例如:如果xhkdb数据库存在,尝试存取它:
9.查看当前使用的数据库
mysql》selectdatabase();
10.当前数据库包含的表信息:
mysql》showtables;(注意:最后有个s)