
此时看到id=2,3的记录username字段相同,如果想查询所有不重复的username,可以执行如下:
SELECT distinct username FROM user
例如执行排序语句: SELECT * FROM user order by id asc得到三条升序的数据,如果想限制只显示2条,可以使用LIMIT关键字: SELECT * FROM user order by id asc limit 0,2。LIMIT后面跟着的表示起始偏移量和前N行记录,默认起始偏移量为0,所以这句话也可以写为: SELECT * FROM user order by id asc limit 2。 LIMIT经常和order by一起配合使用来进行分页显示。
聚合 *** 作的语法涉及下面几个参数:
示例:
表连接从大类上分为内连接和外连接。二者区别在于内连接只选出两张表中互相匹配的记录,外连接会选出其他不匹配的记录。
示例:
创建一个雇员表deployee,有五个人:
再创建一个部门表,有4个部门:
某些情况下,查询的条件是另外一个select语句的结果,这时用到子查询。子查询关键字有in,not in,= ,!=,exists,not exists等。
如执行 select * from deployee where deployee.dep_id in (select dep_id from department)也表示查询有部门的雇员。如果子查询记录数唯一,可以使用=代替in:
select * from deployee where deployee.dep_id in (select dep_id from department where dep_id = 'sale') 由于子查询只有一条记录,所有可以用等号
如果要求将两个表的数据按照一定的查询条件查询出来后,将结果合并到一起显示出来,需要使用union和union all关键字来实现。
union 和 union all的主要区别是union all是把结果集直接合并在一起,而union 是将union all后的结果进行一次distinct,去除重复的记录。
示例:
where子句设置了搜索条件 它在insert update delete语句中的应用方法也与在select语句中的应用方法完全相同 搜索条件紧跟在关键词where的后面 如果用户要在语句中使用多个搜索条件 则可用and或or连接 搜索条件的基本语法是[not] expression parison_operator expression[not] expression [not] like match_string [not] expression is [not] null[not] expression [not] beeen expression and expression[not] column_name join_operator column_name[not] boolean_expression
and 用来联结两个条件 并在两个条件都是TRUE的时候返回结果 当在同一语句中使用多个逻辑运算符时 and运算符总是最优先 除非用户用括号改变了运算顺序
or 用来联结两个条件 当两个条件中有任一条件是TRUE的时候返回结果 当在同一语句中使用多个逻辑运算符时 运算符or通常在运算符and之后进行运算 当然用户可以使用括号改变运算的顺序
beeen 用来标识范围下限的关键词 and后面跟范围上限的值 范围where @val beeen x and y包含首尾值 如果beeen后面指定的第一个值大于第二个值 则该查询不返回任何行
column_name 在比较中使用的列名 在会产生歧义时 一定要指明列所在的表名
parison_operator 比较运算符 见下表
Word WRAP: break word bgColor=#f f f >以下是引用片段 符号 意义 = 等于 > 大于 < 小于 >= 大于等于 <= 小于等于 != 不等于 <> 不等于
在比较char varchar型 数据 时 <的意思是更接近字母表头部 >代表更接近字母表尾部 一般来说 小写字母大于大写字母 大写字母大于数字 但是这可能依赖于 服务器 上 *** 作系统 的比较顺序
在比较时 末尾的空格是被忽略的 例如 Dirk 等于 Dirk
在比较日期时 <表示早于 >表示晚于
在使用比较运算符比较character和datetime数据时 需用引号将所有数据引起来
expression 可能是列名 常数 函数或者是列名或常数的任意组合 以及以算术运算符或逐位运算符连接的函数 算术运算符如下表所示
以下是引用片段 符号 意义 + 加号 减号 * 乘号 / 除号
is null 在搜索一个NULL值时使用
like 关键词 对char varchar和datetime(不包括秒和毫秒)可以使用like 在 MySQL 中like也可以用在数字的表达式上
当用户在搜索datetime型 数据 时 最好是使用关键词like 因为完整的datetime记录包含各种各样的日期组件 例如用户在列arrival_time中加入一个值 : 而子句where arrival_time= : 却没有发现它 因为MySQL把录入的数据转换成了 Jan : AM 然而子句where arrival_time like % : % 就能找到它
boolean_expression 返回 true 或 false 值的表达式
match_string 由字符和通配符组成的串 用单引号或双引号引起来 是匹配模式 通配符如下表所示
Word WRAP: break word bgColor=#f f f >以下是引用片段 符号 意义 % 或多个字符的字符串 _ 任何一单个字符 not 否定任何逻辑表达式 或是关键词 如like null beeen等 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 这三句是完全等价的 当然 我们不赞成用第三种用法 这将给程序的可读性带来不好的影响 为了以降序排列 把DESC关键词加到order by子句中你要排序的列名前 缺省是升序 你也可以用ASC关键词明确指定
limit 子句 用来限制select语句返回的行数 limit取 个或 个数字参数 如果给定 个参数 第一个指定要返回的第一行的偏移量 第二个指定返回行的最大数目 初始行的偏移量是 (不是 ) 如果给定一个参数 它指出偏移量为 的返回行的最大数目 也就是说limit 和limit 完全等价
至于procedure关键词的含义 我也没搞得太清楚 好象是对存储过程的支持 而MySQL本身不支持存储过程 看来是为了将来扩充的需要而保留的吧
lishixinzhi/Article/program/MySQL/201311/29617SQL SELECT命令被用来获取数据从MySQL数据库。可以使用此命令在mysql>提示符下或使用脚本,如PHP。
语法:
下面是通用的SQL SELECT命令的语法来从MySQL表提取数据:
?123 SELECT field1, field2,...fieldN table_name1, table_name2... [WHERE Clause] [OFFSET M ][LIMIT N]
1.可以使用一个或多个以逗号分隔的表,包括各种使用WHERE子句条件。但是WHERE子句的SELECT命令是一个可选部分。
2.可以在一个单一的SELECT命令读取一个或多个字段。
3.可以指定星号(*)的字段的地方。在这种情况下,SELECT将返回所有的字段4.可以使用WHERE子句指定任何条件。
5.可以指定偏移用SELECT将开始返回记录的偏移量。默认情况下,偏移量为06.可以限制返回的使用LIMIT属性的数量。
从命令提示符获取数据:
这将使用SQL SELECT命令来从MySQL表tutorials_tbl获取数据例子:
下面的例子将返回所有记录tutorials_tbl表:
?123456789101112131415 root@host# mysql -u root -p passwordEnter password:******* mysql>use TUTORIALSDatabase changed mysql>SELECT * from tutorials_tbl +-------------+----------------+-----------------+-----------------+ | tutorial_id | tutorial_title | tutorial_author | submission_date | +-------------+----------------+-----------------+-----------------+ | 1 | Learn PHP | John Poul| 2007-05-21 | | 2 | Learn MySQL | Abdul S | 2007-05-21 | | 3 | JAVA Tutorial | Sanjay | 2007-05-21 | +-------------+----------------+-----------------+-----------------+ 3 rows in set (0.01 sec) mysql>
使用PHP脚本获取数据:
您可以使用相同的SQL SELECT命令进入PHP函数mysql_query()。这个函数是用来执行SQL命令后,另一个PHP函数mysql_fetch_array()可以用来获取所有选定的数据。这个函数返回的行作为一个关联数组/数字数组或两者。如果没有更多的行这个函数返回FALSE。
下面是一个简单的例子,获取记录tutorials_tbl表。
例子:
试试下面的例子显示tutorials_tbl表的所有记录。
?123456789101112131415161718192021222324252627282930 <?php $dbhost = 'localhost:3036'$dbuser = 'root'$dbpass = 'rootpassword'$conn = mysql_connect($dbhost, $dbuser, $dbpass)if(! $conn ) { die('Could not connect: ' . mysql_error())} $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl' mysql_select_db('TUTORIALS')$retval = mysql_query( $sql, $conn )if(! $retval ) { die('Could not get data: ' . mysql_error())} while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Tutorial ID :{$row['tutorial_id']} <br>". "Title: {$row['tutorial_title']} <br>". "Author: {$row['tutorial_author']} <br>". "Submission Date : {$row['submission_date']} <br>". "--------------------------------<br>"} echo "Fetched data successfully\n"mysql_close($conn)?>
这些行的内容被分配到变量$row,行中的值,然后打印。
注: 一定要记住,当要插入到一个字符串数组的值直接用花括号。
在上面的例子中不断MYSQL_ASSOC作为PHP函数mysql_fetch_array()第二个参数,以便它返回一个关联数组的行为。一个关联数组,可以使用他们的名字,而不是使用索引访问字段。
PHP提供了另一种称为mysql_fetch_assoc()函数也返回该行作为关联数组。
实例:
试试下面的例子显示从tutorial_tbl表的所有记录,使用mysql_fetch_assoc()函数。
?123456789101112131415161718192021222324252627282930 <?php $dbhost = 'localhost:3036'$dbuser = 'root'$dbpass = 'rootpassword'$conn = mysql_connect($dbhost, $dbuser, $dbpass)if(! $conn ) { die('Could not connect: ' . mysql_error())} $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl' mysql_select_db('TUTORIALS')$retval = mysql_query( $sql, $conn )if(! $retval ) { die('Could not get data: ' . mysql_error())} while($row = mysql_fetch_assoc($retval)) { echo "Tutorial ID :{$row['tutorial_id']} <br>". "Title: {$row['tutorial_title']} <br>". "Author: {$row['tutorial_author']} <br>". "Submission Date : {$row['submission_date']} <br>". "--------------------------------<br>"} echo "Fetched data successfully\n"mysql_close($conn)?>
也可以使用常量MYSQL_NUM,作为第二个参数的PHP函数mysql_fetch_array()。这将导致该函数返回一个数字索引的数组。
实例:
试试下面的例子显示使用MYSQL_NUM参数tutorials_tbl表中的所有记录。
?123456789101112131415161718192021222324252627282930 <?php $dbhost = 'localhost:3036'$dbuser = 'root'$dbpass = 'rootpassword'$conn = mysql_connect($dbhost, $dbuser, $dbpass)if(! $conn ) { die('Could not connect: ' . mysql_error())} $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl' mysql_select_db('TUTORIALS')$retval = mysql_query( $sql, $conn )if(! $retval ) { die('Could not get data: ' . mysql_error())} while($row = mysql_fetch_array($retval, MYSQL_NUM)) { echo "Tutorial ID :{$row[0]} <br>". "Title: {$row[1]} <br>". "Author: {$row[2]} <br>". "Submission Date : {$row[3]} <br>". "--------------------------------<br>"} echo "Fetched data successfully\n"mysql_close($conn)?>
所有上述三个例子,将产生相同的结果。
释放内存:
它是一种很好的做法,在每一个SELECT语句释放游标内存。这可以通过使用PHP函数了mysql_free_result()。下面的例子来说明它是如何被使用的。
实例:
试试下面的例子
?12345678910111213141516171819202122232425262728293031 <?php $dbhost = 'localhost:3036'$dbuser = 'root'$dbpass = 'rootpassword'$conn = mysql_connect($dbhost, $dbuser, $dbpass)if(! $conn ) { die('Could not connect: ' . mysql_error())} $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl' mysql_select_db('TUTORIALS')$retval = mysql_query( $sql, $conn )if(! $retval ) { die('Could not get data: ' . mysql_error())} while($row = mysql_fetch_array($retval, MYSQL_NUM)) { echo "Tutorial ID :{$row[0]} <br>". "Title: {$row[1]} <br>". "Author: {$row[2]} <br>". "Submission Date : {$row[3]} <br>". "--------------------------------<br>"} mysql_free_result($retval)echo "Fetched data successfully\n"mysql_close($conn)?>
在获取数据的同时可以编写复杂的SQL,只要喜欢。程序将保持与上述相同。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)