MySQL(四)---SELECT语法

一,数据库语句

数据库数据是通过DML语句管理数据库数据,包括:

  • INSERT (添加数据语句)
  • UPDATE (更新数据语句)
  • DELETE (删除数据语句)

1:INSERT (添加数据语句)

INSERT INTO 表名[(字段1,字段2,字段3,...)] VALUES('值1','值2','值3')

#注意 :
1,字段或值之间用英文逗号隔开;
2,'字段1,字段2...'该部分可省略 , 但添加的值务必与表结构,数据列,顺序相对应,且数量一致;
3,可同时插入多条数据 , values 后用英文逗号隔开

2:UPDATE (更新数据语句)

UPDATE 表名 SET column_name=value [,column_name2=value2,...] [WHERE condition];

#注意 :
1,column_name 为要更改的数据列;
2,value 为修改后的数据 , 可以为变量 , 具体指 , 表达式或者嵌套的SELECT结果;
3,condition 为筛选条件 , 如不指定则修改该表的所有列数据

3:DELETE (删除数据语句)

DELETE FROM 表名 [WHERE condition];

#注意 :  condition为筛选条件 , 如不指定则删除该表的所有列数据

二,DQL( Data Query Language 数据查询语言 )

查询数据库数据 , 如SELECT语句,简单的单表查询或多表的复杂查询和嵌套查询,DQL是数据库语言中最核心,最重要的语句也是使用频率最高的语句

1,指定查询字段

# 查询所有学生信息
SELECT * FROM student;

# 查询指定列(学生的学号和姓名)
SELECT studentno,studentname FROM student;

2,DISTINCT关键字的使用

作用 : 去掉SELECT查询返回的记录结果中重复的记录(返回所有列的值都相同),只返回一条

# 查看哪些同学参加了考试(学号)--去除重复项
SELECT * FROM result;
SELECT studentno FROM result;
SELECT DISTINCT studentno FROM result;

#说明:一个学生有很5课成绩,但是只有他1个学号,如果不加DISTINCT,
只执行SELECT studentno FROM result;,那么会根据他的5课成绩查出5个学号的,
如果加了DISTINCT,去掉重复项,那么就只有一个学号了

3,where条件语句

用于检索数据表中符合条件的记录,搜索条件可由一个或多个逻辑表达式组成 , 结果一般为真或假

# 查询考试成绩在95-100之间的学生学号
SELECT Studentno,StudentResult
FROM result
WHERE StudentResult>=95 AND StudentResult<=100;

# AND也可以写成 &&
SELECT Studentno,StudentResult
FROM result
WHERE StudentResult>=95 && StudentResult<=100;

# 除了1000号同学,要其他同学的成绩
SELECT studentno,studentresult
FROM result
WHERE studentno!=1000;

# 使用NOT
SELECT studentno,studentresult
FROM result
WHERE NOT studentno=1000;

4,模糊查询

#查询姓李的同学的学号及姓名
#like结合使用的通配符 : % (代表0到任意个字符)  _ (一个字符)
SELECT studentno,studentname FROM student
WHERE studentname LIKE '李%';

#查询姓李的同学,后面只有一个字的
SELECT studentno,studentname FROM student
WHERE studentname LIKE '李_';

#查询姓李的同学,后面只有两个字的
SELECT studentno,studentname FROM student
WHERE studentname LIKE '李__';

#查询姓名中含有 文 字的
SELECT studentno,studentname FROM student
WHERE studentname LIKE '%文%';

#查询学号为1000,1001,1002的学生姓名
SELECT studentno,studentname FROM student
WHERE studentno IN (1000,1001,1002);

#查询地址在北京,南京,河南洛阳的学生学号姓名
SELECT studentno,studentname,address FROM student
WHERE address IN ('北京','南京','河南洛阳');

#查询出生日期没有填写的同学
#不能直接写=NULL , 这是代表错误的 , 用 is null
SELECT studentname FROM student
WHERE BornDate IS NULL;

#查询出生日期填写的同学
SELECT studentname FROM student
WHERE BornDate IS NOT NULL;

#查询没有写家庭住址的同学(空字符串不等于null)
SELECT studentname FROM student
WHERE Address='' OR Address IS NULL;

5,连接查询

连接查询: 如需要多张数据表的数据进行查询,则可通过连接运算符实现多个查询
1,内连接 inner join:查询两个表中的结果集中的交集
2,外连接 outer join:
2-1,左外连接 left join:以左表作为基准,右边表来一一匹配,匹配不上的,返回左表的记录,右表以NULL填充
2-2,右外连接 right join:以右表作为基准,左边表来一一匹配,匹配不上的,返回右表的记录,左表以NULL填充

#查询参加了考试的同学信息(学号,学生姓名,科目编号,分数)
SELECT * FROM student;
SELECT * FROM result;

#查询student表的学生学号=result表的学生学号时的同学信息(学号,学生姓名,科目编号,分数)
#内连接
SELECT s.studentno,studentname,subjectno,StudentResult
FROM student s
INNER JOIN result r
ON r.studentno = s.studentno

# 右连接(也可实现)
SELECT s.studentno,studentname,subjectno,StudentResult
FROM student s
RIGHT JOIN result r
ON r.studentno = s.studentno

# 等值连接
SELECT s.studentno,studentname,subjectno,StudentResult
FROM student s , result r
WHERE r.studentno = s.studentno

# 左连接 (查询了所有同学,不考试的也会查出来)
SELECT s.studentno,studentname,subjectno,StudentResult
FROM student s
LEFT JOIN result r
ON r.studentno = s.studentno

#查一下缺考的同学(左连接应用场景)
SELECT s.studentno,studentname,subjectno,StudentResult
FROM student s
LEFT JOIN result r
ON r.studentno = s.studentno
WHERE StudentResult IS NULL

6,排序和分页

ORDER BY 语句用于根据指定的列对结果集进行排序,默认按照ASC升序对记录进行排序。

# 查询C语言-1的考试结果(学号 学生姓名 科目名称 成绩)
# 按成绩降序排序
SELECT s.studentno,studentname,subjectname,StudentResult
FROM student s
INNER JOIN result r
ON r.studentno = s.studentno
INNER JOIN `subject` sub
ON r.subjectno = sub.subjectno
WHERE subjectname='C语言-1'
ORDER BY StudentResult DESC , studentno  

# 每页显示5条数据
SELECT s.studentno,studentname,subjectname,StudentResult
FROM student s
INNER JOIN result r
ON r.studentno = s.studentno
INNER JOIN `subject` sub
ON r.subjectno = sub.subjectno
WHERE subjectname='C语言-1'
ORDER BY StudentResult DESC , studentno
LIMIT 0,5

原文地址:https://www.cnblogs.com/tqsh/p/11314663.html

时间: 2024-10-08 22:22:11

MySQL(四)---SELECT语法的相关文章

mysql之select语法

一:连接查询(外链接outer和内链接inner) 连接查询是另一种类型的多表查询.连接查询对多个表进行JOIN运算,简单地说,就是先确定一个主表作为结果集,然后,把其他表的行有选择性地"连接"在主表结果集上. 语法:两个表的连接(left join table1 on ... 默认就是外链接即 left outer join table1 on ...) SELECT t1.*,t2.* FROM t1 (INNER | LEFT | RIGHT) JOIN t2 ON t1.col

mysql数据库操作语法大全

1.连接Mysql 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL. 首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root -p,回车后提示你输密码.注意用户名前可以有空格也可以没有空格,但是密码前必须没有空格,否则让你重新输入密码. 如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是: mysql> 2.连接到远程主机上的MYSQL.假设远程主机的IP为:1

Pascal、VB、C#、Java四种语法对照表

因为工作原因,自学会了vb后陆续接触了其它语言,在工作中经常需要与各家使用不同语言公司的开发人员做程序对接,初期特别需要一个各种语法的对照比,翻看了网络上已有高人做了整理,自己在他基础上也整理了一下,摘抄如下(最后附上原作,网上也可以找到): 类别 Vb6 & Vb.Net Delphi C# 语法 不区分大小写 不区分大小写 区分大小写 数据类型 数据     关键字    占用字节      类型符 整型          integer 长整型        long 单精度型     

MySQL 使用SELECT ... FOR UPDATE 做事务写入前的确认(转)

Select…For Update语句的语法与select语句相同,只是在select语句的后面加FOR UPDATE [NOWAIT]子句. 该语句用来锁定特定的行(如果有where子句,就是满足where条件的那些行).当这些行被锁定后,其他会话可以选择这些行,但不能更改或删除这些行,直到该语句的事务被commit语句或rollback语句结束为止. MySQL  使用SELECT ... FOR UPDATE 做事务写入前的确认 以MySQL 的InnoDB 为例,预设的Tansactio

全面掌握Mysql及select支持的运算操作

转载请注明出处:http://blog.csdn.net/lhy_ycu/article/details/45725317 花了2天时间整理了一下Mysql中的常用命令及select支持的运算操作,希望这篇博客对大家有所帮助. 内容提纲 1.登录mysql 2.查看mysql信息 3.查看所有数据库 4.打开指定数据库 5.李处指定数据库中的所有表 6.查看指定表的结构 7.查看建表语句 8.建库建表 9.修改指定表结构 10.查看数据库的编码方式 11.DML语句(CRUD)操作 12.注释方

sql点滴41—mysql常见sql语法

原文:sql点滴41-mysql常见sql语法 ALTER TABLE:添加,修改,删除表的列,约束等表的定义. 查看列:desc 表名; 修改表名:alter table t_book rename to bbb; 添加列:alter table 表名 add column 列名 varchar(30); 添加带注释的列:alter table directory add index_url varchar(256) default null comment '章节书目链接' after di

mysql数据库 select语句全集

1.select 1.1 作用 获取mysql中的数据行 1.2 单独使用select 1.2.1 select @@XXX:获取参数信息 select @@port; 查端口号 show variables; 查看所有参数 show variables like '%innodb%'; |查参数 1.2.2 select 函数(): select now(); 函数加括号 mysql> select database(); |库 mysql> select now(); |时间 mysql&

MySQL UNION 操作符:语法及案例剖析

MySQL UNION 操作符 本教程为大家介绍 MySQL UNION 操作符的语法和实例. 描述 MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中.多个 SELECT 语句会删除重复的数据. 语法 MySQL UNION 操作符语法格式: SELECT expression1, expression2, ... expression_n FROM tables [WHERE conditions] UNION [ALL | DISTINCT] S

MySQL SHOW INDEX语法的实际应用

以下的文章主要描述的是MySQL SHOW INDEX语法的实际操作用法以及其实际查看索引状态(语法)的具体内容的描述,如果你对这一技术,心存好奇的话,以下的文章将会揭开它的神秘面纱. SHOW INDEX FROM tbl_name [FROM db_name] MySQL SHOW INDEX会返回表索引信息.其格式与ODBC中的SQLStatistics调用相似. MySQL SHOW INDEX会返回以下字段: Table 表的名称. Non_unique 如果索引不能包括重复词,则为0