首页 > 数据库技术 > 详细

SQL 语法基础

时间:2021-06-22 00:00:07      阅读:26      评论:0      收藏:0      [点我收藏+]

1、常见SQL语句

 

1.1 SQL介绍

1、SQL是用于访问和处理数据库的标准的计算机语言。SQL,指结构化查询语言,全称是Structured Query Language.

2、SQL让您可以访问和处理数据库。

3、SQL是一种ANSI(American National Standards Institute美国国家标准化组织)标准的计算机语言。

 

1.2 SQL特点

SQL面向数据库执行查询

SQL可从数据库取回数据

SQ可在数据库中插入新的记录

SQL可更新数据库中的数据

SQL可从数据库删除记录

SQL可创建新数据库

SQL可在数据库中创建新表

SQL可在数据库中创建存储过程

SQL可在数据库中创建视图

SQL可以设置表、存储过程和视图的权限

 

1.3 数据库操作

(1)连接数据库

明文连接

mysql -h127.0.0.1 -P3306 -uroot -proot--明文

如果连接本地数据库 -h 可以省略如果服务器端口是3306,-P端口号也可以省略.

mysql -uroot -proot --明文

密文连接

mysql -uroot -p

Enter password:****

 

(2)退出数据库

EXIT 方法一

quit 方法二

q           方法三

ctrl+c    方法四

注意:SQL语句最后需要有分号;结尾

 

MySQL简介

MySQL基本结构:

库:MySQL下可以存在多个库,可以理解为一个仓库。

表:一个库下可以存放多个表,仓库内的储物架。

列:字段名,类似表格的列,储物架上的不同的列。

值:存放的数据,存放的工具。

 

1.4 常用的 SQL 语句

查询当前数据库版本:    select version();

查询当前数据库用户:    select user();

查询当前路径:               select @@basedir;

查询所有数据库:          show databases;

选择一个数据库:           use+数据库名;

查询当前数据库:           select database();

查询所有表名:               show tables;

创建一个数据库:           create database数据库名;

删除一个数据库:           drop database数据库名;

查询一个表的结构:        desc表名;

 

1.5 数据库表得运用

(1)创建表

语法:

create table数据表名字(字段类型约束[,字段类型约束]);

约束:

auto_increment 表示自动增长

not null 表示不能为空

primary key 表示主键

default 默认值

(2)举例

在class数据库下创建student表(id、name、age、sex、birthday)

create table student(id int,name varchar(20),age int,sex varchar(20),birthdayint);

 

 

2、SQL 增删改查

2.1 SQL语句-增添数据

一、为表中所有字段添加数据

(1)INSERT语句中指定所有字段名

语法:INSERT INTO表名 (字段名1,字段名2,..) VALUES(值1,值2,...);

例题:向数据库class下student表中插入(id为1,姓名::xiaoqiao,年龄:18,性别::woman,生日:2002)数据。

insert into student(id,name,age,sex,birthday) values(1,"xaoqiao",18,"woman" "2002");

(2)INSERT语句中不指定字段名

语法:INSERT INTO表名VALUES(值11,值2,...);

例题:向数据库class下student表中插入(id为2,姓名: daqiao,年龄: 20,性别: woman,生日:2004)数据。

inset into student values(2,"daqiao",20,"woman","2000");

 

二、为表的指定字段添加数据

(1)为指定字段添加数据,即只向部分字段添加值,而其它字段的值为表定义时的默认值。

语法:INSERT INTO表名(字段1,字段2,...) VALUES(值1,值2,.…..);

例题:向数据库class下student表中插入(id为3,姓名: zhouyu,年龄:18,)数据。

insert into student(id,name,age) values(3,"xaoqiao",18);

(2)同时添加多条数据

语法:INSERT INTO表名(字段名1,字段名2,...)VALUES (值1,值2,...).(值1,值2);

例题:向数据库class下student表中插入(id为4,姓名: sunce,年龄:20,性别: man,生日:2004)和(id为5,姓名: caocao,年龄:20,性别: man,生日:2004)数据。

insert into student values(4,"sunce",20,"man" ,"2000"),(5,"caocao",20,"man" ;"2000");

 

2.2 SQL语句-删除数据

删除部分数据

(1)即删除指定的部分数据,需要使用WHERE子句来指定删除记录的条件。

语法:DELETE FROM表名WHERE条件表达式;

例题:向数据库class 下student表中删除id为1的数据。

delete from student where id=1;

删除全部数据

(2)若DELETE语句中没有使用WHERE语句,则会将表中所有记录都删除。。

语法一:DELETE FROM表名;

例题:向数据库class 下student表中删除所有的数据。

delete from student ;

语法二:TRUNCTE[TABLE]表名;

 

2.3 SQL语句-修改数据

UPDATE更新部分数据

(1)指更新指定表中的指定记录,使用WHERE子句来指定。

语法:UPDATE表名SET字段名1=值1,[,字段名2=值2,..][ WHERE条件表达式];

例题:向数据库class下student表中id为1的数据中字段age改为16,字段birthday改为2004。

update student set age=16,birthday=2004 where id=1;

update student set age=17;

UPDATE更新全部数据

(2)若DELETE语句中没有使用WHERE语句,则会将表中所有记录都删除。

语法:DELETE FROM表名;

例题:向数据库class 下student表中将age字段都该为17。

update student set age=17;

 

2.4 SQL语句-查询数据

1、简单查询

(1)查询所有字段

语法:SELECT字段名1,字段名2,...FROM表名;

例题:查询数据库class下查student表中所有数据。

SELECT id,name,age ,sex,birthda FROM student;

select * from student;

 

(2)查询指定的部分字段

语法:SELECT字段名1,字段名2,...FROM表名;

例题:查询数据库class 下student表中所有的name字段和gender字段。

SELECT name,sex FROM student;

注意:字段顺序可以更改,则显示的结果也会作出对应的调整。

 

2、按条件查询

(1)带关系运算符的查询

语法:SELECT字段名1,字段名2,...FROM表名WHERE条件表达式;

例题:查询数据库class下查student表中id为4的人的id和name字段。

SELECT id,name FROM student WHERE id=4;

(2)带IN关键字的查询

语法:SELECT*字段名1,字段名2.FROM表名WHERE 字段名[NOT] IN(元素1,元素2,...);

解释:IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来。

例题:查询数据库class 下student表中id值为1,2,3的记录。

SELECT* FROM student WHERE id lN(1,2.,3);

 

(3)带BETWEEN AND 关键字的查询

语法:SELECT*{字段名1.字段名2...FROM表名WHERE 字段名[NOT]BETWEEN值1 AND值2;

解释:BETWEEN AND用于判断某个字段的值是否在指定范围之内,若在,则该字段所在的记录会被查询出来,反之不会。

例题:查询数据库class下查student表中id值在2~5之间的人的id和name。

SELECT id,name FROM student WHERE id BETWEEN 2AND 5;

 

(4)空值查询

语法:SELECT*字段名1,字段名2,...FROM表名WHERE 字段名IS [ NOT ]NULL

解释:在数据表中有些值可能为空值(NULL),空值不同于0,也不同于空字符串,需要使用IS NULL来判断字段的值是否为空值。

例题:查询数据库class 下student表中sex值为空值的记录。

SELECT* FROM student WHERE sex IS NULL;

注意:IS NOT NULL关键字用来查询字段不为空值的记录。

 

(5)带DISTINCT关键字的查询

语法:SELECT DISTINCT字段名FROM表名;

解释:很多表中某些字段的数据存在重复的值,可以使用DISTINCT关键字来过滤重复的值,只保留一个值。

例题:查询数据库class下查student表中birthday字段的值,结果中不允许出行重复的值。

ELECT DISTINCT birthday FROM student;

 

(6)带LIKE关键字的查询

① 百分号(%)通配符

语法:SELECT*|字段名1,字段名2,.….FROM表名WHERE字段名[NOT]LIKE "匹配字符串‘;

解释:匹配任意长度的字符串,包括空字符串。例如,字符串" |%"匹配以字符 | 开始,任意长度的字符串,如" ct ", " cut " ," current "等,字符串" c%g "表示以字符c开始,以 g 结尾的字符串,字符串"%y%"表示包含字符“y "的字符串,无论“ y"在字符串的什么位置。

例题:查询数据库class下student表中name字段以字符“ s ”开头的人的id,name。

SELECT id,name FROM student WHERE name LIKE"s%";

② 下划线(_)通配符

语法:SELECT*|字段名1,字段名2,.….FROM表名WHERE 字段名[NOT]LIKE‘匹配字符串‘;

解释:下划线通配符只匹配单个字符,若要匹配多个字符,需要使用多个下划线通配符。例如,字符串" cu_"匹配以字符串" cu "开始,长度为3的字符,如"cut " ," cup";字符串" c__"匹配在" c “和" I"之间包含两个字符的字符串,如" cool"。需要注意的是,连续的"_"之间不能有空格,例如"M_ _QL"只能匹配“MySQL”,不能匹配"My SQL"。

例题:查询数据库class下student表中name字段值以"xia"开始,以“qiao "结束,并且中间只有一个字符的记录。

SELECT*FROM student WHERE name LIKE ‘xia_qiao‘;

注意:若要查询的字段值本来就含有“%”或者“_”,则要用“\”进行转义,如要查询本身含有“%”的字符串,命令应改为”%\%%”。

 

(7)带AND关键字的多条件查询

语法:SELECT*|字段名1,字段名2,...FROM表名;

解释:在使用SELECT语句查询数据时,优势为了使查询结果更加精确,可以使用多个查询条件,如使用AND关键字可以连接两个或多个查询条件。

例题:查询数据库class下student表中id字段小于5,并且sex‘字段值为“woman "的人的id和name

SELECT id,name FROM student WHERE id<5AND sex=‘woman‘;

 

(8)带OR关键字的多条件查询

语法:SELECT*|字段名1,字段名2,...FROM表名WHERE 条件表达式1OR条件表达式2[ ...OR条件表达式n ];

解释:与AND关键字不同,OR关键字只要满足任意一个条件就会被查询出来。

例题:查询数据库class下student表中id字段小于5,或者sex字段值为“woman "的人的id和name

SELECT id,name FROM student WHERE id<5 OR sex=‘woman‘;

 

(9)OR和AND一起使用的情况

语法:SELECT*|字段名1,字段名2,...FROM表名;

解释:OR和AND一起使用的时候,AND的优先级高于OR,因此二者一起使用时,会先运算AND两边的表达式,再运算OR两边的表达式。

例题:查询数据库class下student表中sex值为"“woman"或者sex值为“man"并且age字段值为16的人的记录

SELECT*FROM student WHERE sex=‘woman‘ OR sex=‘man‘AND age=16;

 

3、聚合函数

(1) COUNT()函数:统计记录的条数

语法:SELECT COUNT(*)FROM表名;

例题:查询数据库class下student表中一共有多少条记录。

SELECT COUNT(*)FROM student;

(2) sUM()函数:求出表中某个字段所有值的总和

语法:SELECT SUM(字段名)FROM表名;。

例题:查询数据库class 下student表中age字段的总和

SELECT SUM(age)FROM student;

(3)AVG()函数:求出表中某个字段所有值的平均值

语法:SELECT AVG(字段名)FROM表名;

例题:查询数据库class 下student表中表中age字段的平均值。

SELECT AVG(age)FROM student;

(4)MAX()函数:求出表中某个字段所有值的最大值

语法:SELECT MAX(字段名)FROM表名;

例题:查询数据库class下student表中age字段的最大值

SELECT MAX(age)FROM student;

(5)MIN()函数:求出表中某个字段所有值的最小值

语法:SELECT MIN(字段名)FROM表名;

例题:查询数据库class下student表中grade字段的最小值

SELECT MIN(age)FROM student;

 

4、对查询结果进行排序

(1) 带ORDER BY关键字的排序

语法:SELECT 字段名1,字段名2,...FROM表名ORDERBY字段名1[ASC | DESC ],字段名2[ASC | DESC ]...;

解释:在该语法中指定的字段名是对查询结果进行排序的依据,ASC表示升序排列,DESC表示降序排列,默认情况是升序排列。

例题:查询数据库class下student表中的所有记录,并按照age字段进行升序排序

SELECT* FROM student ORDER BY age;

(2)带GROUP BY关键字的分组查询

语法:语法:SELECT字段名1,字段名2,..FROM表名GROUPBY字段名1,字段名2,...[ HAVING条件表达式];

解释:在对表中数据进行统计的时候,可以使用GROUP BY按某个字段或者多个字段进行分组,字段中值相同的为一组,如男生分为一组,女生分为一组。

① 单独使用GROUP BY进行分组

解释:单独使用GROUP BY关键字,查询的是每个分组中的一条记录。

例题:查询数据库class 下student表中的数据,按照sex字段进行分组

SELECT *FROM student GROUP BY sex;

② GROUP BY和聚合函数一起使用

解释:GROUP BY和聚合函数一起使用,可以统计出某个或者某些字段在一个分组中的最大值、最小值、平均值等。

例题:查询数据库class下student表中按照age字段进行分组查询,计算出每组共有多少个人。

SELECT COUNT(*) ,age FROM student GROUP BY age;

③ GROUP BY和HAVING关键字一起使用

解释:HAVING关键字和WHERE关键字的作用相同,区别在于HAVING关键字可以跟聚合函数,而WHERE关键字不能。通常HAVING关键字都和GROUP BY一起使用,用于对分组后的结果进行过滤。

例题:查询数据库class下student表中按照sex字段进行分组查询,查询出age字段值之和小于300的分组

SELECT sum(age),sex FROM student GROUP BY sex HAVING SUM(age)<300;

 

(3) 使用LIMIT限制查询结果的数量

语法:SELECT 字段名2,字段名2,...FROM表名LIMIT记录数[OFFSET]记录数LIMIT Y OFFSETX向后偏移x位。

解释:在此语法中,LIMIT后面可以跟两个参数,第一个参数" OFFSET 表示偏移量,如果偏移量为O,则从查询结果第一条记录开始,偏移量为1则从查询结果中的第二条记录开始,以此类推。OFFSET为可选值,默认值为0,第二个参数"记录数"表示指定返回查询记录的条数。

例题:查询数据库class下student表中的前四条记录

SELECT *FROM student LIMIT 4;

例题:查询数据库class 下student表中的前四条记录

SELECT *FROM student ORDER BY age DESC LIMIT 2,1;

 

5、为表和字段取别名

(1)为表取别名

语法:SELECT*FROM表名[AS ]别名;

解释:在进行查询操作时,如果表名很长使用起来不方便,可以为表取一个别名来代替表的名称。

例题:为student表起一别名s,并查询student2表中sex字段值为“woman"的记录

SELECT *FROM student LIMIT 4;

例题:查询数据库class下student表中的前四条记录

SELECT * FROM student AS s WHERE s.sex=‘woman‘;

(2)为字段取别名

语法: SELECT字段名[AS ]别名[ ,字段名[AS]别名,..] FROM表名;

例题:查询student表中的所有记录的name和sex字段值,并未这两个字段起别名stu_name和stu_sex

SELECT name AS stu_name,sex AS stu_gender FROM student;

 

6、子查询

select name from student where id <(select age from student where name=‘sunce‘);

7、联合查询(union)

select version() union select user();

8、嵌套查询

select count(*") from users where id=(select id from users where id=1 and username=(select usernamefrom users where address=‘China‘));

select count(*) from (select * from student2) as s;

 

9、利用内置表查询

查询数据库:select schema_name from information_schema.schemata;

查询表名:select table_name from information_schema.tables;

查询名:select column_name from information_schema.columns;

查询数据:select * from students;

10、另一种

select table_name from mysql.innodb_table_stats where database_name = database();

select table_name from mysql.innodb_index_stats where database_name = database();

 

 

 

 

 

 

SQL 语法基础

原文:https://www.cnblogs.com/Chinarysj/p/14915755.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!