
整句意思是 从 三个 表 "学生" ,"专业" , "公寓" 里查出满足 当 "学生"里的专业简称 等于 "专业"里 的 专业简称 和 "学生"里的公寓类别等于"公寓"里的公寓类别 条件的 记录,从这些记录里取出 "学生"的学号 姓名的值, "专业"的专业简称,学制的值,"公寓"的公寓类别 ,住宿费的值
select 字段名 from 表名 where 条件;
这是select 语句的基本语法,意为在表中查出满足条件的字段的值
select max(id) from 表 where num=100;--查最大ID
select from 表 where id =(select max(id) from 表 where num=100) and num=100;--查id最大并且num为100的那条数据
SQL SELECT 语句
SELECT 语句用于从表中选取数据。
结果被存储在一个结果表中(称为结果集)。
SQL SELECT 语法
SELECT 列名称 FROM 表名称
以及:
SELECT FROM 表名称
注释:SQL 语句对大小写不敏感。SELECT 等效于 select。
select first 5 c_name,c_stu from class where c_str>30 and c_type=true and c_name like '%二班%' order by c_type desc
唉,我现在都不知道该不该帮你们做作业了。
这样学习下去能真正的学到知识吗。
MySQL的常见 *** 作在这里先做一下总结,已经整合到代码里面,经过检验无误。
复制代码
代码如下:
/创建一个数据库/
create
database
xuning_test;
/说明当时使用数据库对象/
use
xuning_test;
/向数据库中添加表并且定义表的结构/
create
table
person(
id
int
not
null,
name
varchar(16)
not
null,
sex
varchar(16)
not
null,
age
int
not
null,
address
varchar(128)
not
null,
remark
varchar(512)
not
null
);
/向数据库的表中插入数据/
insert
into
person
value
(1,'name_1','men',99,'beijing','This
is
a
frindsheep
boy'),
(2,'name_2','men',88,'shanghai','ok
great'),
(1,'name_3','man',77,'guangzhou','This
is
lickly'),
(1,'name_4','men',66,'beijing','This
is
a
frindsheep
boy'),
(1,'name_5','men',55,'beijing','you
dont
going
to
shool'),
(1,'name_6','man',44,'beijing','This
is
a
frindsheep
boy'),
(1,'name_7','men',33,'beijing','This
is
a
frindsheep
boy'),
(1,'name_8','man',22,'beijing',''),
(1,'name_9','men',11,'beijing','This
is
a
frindsheep
boy')
;
/查询时否成功插入/
select
from
person;
/下面是多种查询方式/
/根据列的名称属性值/
select
name
from
person;
/添加条件-根据性别/
select
name
from
person
where
sex
=
'men';
/也可以用比较符作为条件--一定逗号隔开/
select
name,address
from
person
where
age
>
50;
/看做对象去使用数据库和表的关系=---双表关联--对象关系一定要明确/
select
xuning_testpersonname,
xuning_testpersonid,
xuning_testpersonage,
xuning_testpersonaddress
from
xuning_testperson,
test1test_xuning
where
xuning_testpersonid
=
test1test_xuningid
;
/使用表的别名进行查询/
use
xuning_test;
select
cname,sex
from
person
as
c
where
cage
>
40
and
caddress='beijing';
select的命令比较多了,常用的是select表的列名from表名/视图[where条件groupby字段orderby表的列名asc/desc],当然也可以实现多表关联,selectfroma,bwherea列名=b列名;
当然select可以嵌套,但必须数据库支持,oracle和mysql50以上都支持了,如selectfrom(selectfrom表名)a,select的嵌套是比较复杂,可以实现n重嵌套的。
select还有特殊的用法就是selectinto表名selectfrom表名
即为表的复制,好像sqlserver支持这个的。
知道的就这么多了,应该还有其他的了。
在编程中,经常会用到取数据库中某一段的记录,如果要取前几条记录都是很简单,在asp中,直接用top就可以了,在php中,用limit就可以,但如果要取数据库中的第N条到第N条怎么办呢,也就是要取数据库中间的数据,在php,取中间的数据,可以用limit很自然的就实现了,主要是asp编程中,需要在sql语句中再重新嵌入一个sql语句,下面看看asp和php中不同的sql读取中间几条记录。
1Aess采用top
从表中取出第M条到第N条的记录(如N=M10)
selecttopN-M1from[tableName]where(idnotin(selecttopM-1idfrom[tableName]))
selecttopN-M1from[tableName]asawherenotexists(selectfrom(selecttopM-1from[tableName]orderbyid)bwherebid=aid)orderbyid
注意:上述语句不能取从第1条到第N条的数据(即M=1时失效),因为selecttopN中N必须从1开始(参考:数据库读取前几条记录的SQL语句大全):此问题的解决办法:要取第1到N条的记录,需要使用selecttopN解决。
取数据库第20到第30条中间的十条记录的sql语句
selecttop10from[tableName]whereidnotin(selecttop20idfrom[tableName]orderbyid)
删除前10行
deletefrom[tableName]whereidin(selecttop10idfrom[tableName])
删除10-20条
deletefrom[tableName]whereidin(selecttop20idfrom[tableName])andidnotin(selecttop10idfrom[tableName])
2MySql采用limit
limit子句可以被用于强制select语句返回指定的记录数。limit接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是0(而不是1)
检索记录行11-15
selectfrom[tableName]limit10,15
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/29617
以上就是关于SQL 谁告诉我 select 语句 全部用法全部的内容,包括:SQL 谁告诉我 select 语句 全部用法、数据库SQL查询语句的编写、SQL select 语句等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)