sql语言的规则和规范和基本的select语句

1.sql分类

  • DDL(Data Definition Languages,数据定义语言):这些语句定义了不同的数据库,表,视图,索引等数据库对象,还可以用来创建,删除,修改数据库和表的结构。CREATE.DROP.ALTER
  • DML(Data Manipulation Languages,数据操作语言),用于添加,删除,更新和查询数据库记录,并检查数据完整性。INSERT,DELETE,UPDATE.SELECT
  • DCL(Data Control Language,数据控制语言):用于定义数据库,表,字段,用户的访问权限和安全级别。GRANT,REVOKE,COMMIT,ROLLBACK,SAVEPOINT
  • DQL:数据查询语言。

2.SQL语言的规则和规范

  • sql可以写在一行或多行,为了提高可读性,各子句分行写,必要时使用缩进
  • 每条命令以;或\g或\G结束
  • 关键字不能被缩写也不能分行
  • 关于标点符号:
    必须保证所有的(),单引号,双引号是成队结束的。
    必须使用英文状态下的半角输入方式
    字符串型和日期时间类型的数据可以使用单引号(‘’)表示
    列的别名,尽量使用双引号(" "),而且不建议省略as

2.1 sql大小写规范

mysql在win环境下是大小写不敏感的
mysql在linux下大小写敏感的。
数据库名,表名,表的别名,字段名,字段别名等都小写
关键字,函数名,列名,列的别名是忽略大小写的,
推荐统一的书写规范:

  • 数据库名,表名,表的别名,变量名等都小写
  • sql关键字,函数名,绑定变量等都大写

2.2 注释

单行注释: #注释文字
单行注释:-- 注释文字
多行注释: /* 注释文字 */

3 基本的SELECT语句

3.1 SELECT … FROM

  • SELECT 标识选择那些列 FROM 标识从哪个表中选择
  • SELECT * FROM 表明 选择全部列
    关键字大写,数据列和表明小写

3.2 列的别名

  • 重命名一个列
  • 便于计算
  • 紧跟列名,也可以在列名和别名之间加入关键字AS,别名使用双引号,一边在别名中包含空格或特殊的字符并区分大小写。
  • AS可以省略
  • 建议别名简短,见名知意
SELECT last_name AS "Name", salary*12 "Annual Salary"FROM employees;

3.3 去除重复行 DISTINCT关键字

SELECT DISTINCT department_id FROM employees;

重点注意:
DISTINCT 其实是对后面所有列名的组合进行去重,你能看到最后的结果是 74 条,因为这 74 个部
门id不同,都有 salary 这个属性值。如果你想要看都有哪些不同的部门(department_id),只需
要写 DISTINCT department_id 即可,后面不需要再加其他的列名了。

SELECT DISTINCT department_id,salary FROM employees;

3.4 空值参与运算

  • 所有运算符或列值遇到null值,运算结果都为null
SELECT employee_id,salary,commission_pct, 12 * salary * (1 + commission_pct) "annual_sal"
FROM employees;

重点注意:
在 MySQL 里面, 空值不等于空字符串。一个空字符串的长度是 0,而一个空值的长
度是空。而且,在 MySQL 里面,空值是占用空间的。

3.5 着重号``

我们需要保证表中的字段、表名等没有和保留字、数据库系统或常用方法冲突。如果真的相同,请在SQL语句中使用一对``(着重号)引起来。
常数项:

SELECT '尚硅谷' as corporation, last_name FROM employees;

4 显示表结构

DESC employees;

5 过滤数据

语法:

ELECT 字段1,字段2FROM 表名 WHERE 过滤条件

例:

SELECT employee_id, last_name, job_id, department_id FROM employees 
WHERE department_id = 90 ;

练习

  • 查询员工12个月的工资总和,并起别名为ANNUAL SALARY
SELECT employee_id , last_name,salary * 12 "ANNUAL SALARY"
FROM employees;
SELECT employee_id,last_name,salary * 12 * (1 + IFNULL(commission_pct,0)) "ANNUAL
SALARY"
FROM employees;
  • 查询employees表中去除重复的job_id以后的数据
SELECT DISTINCT job_id FROM employees;
  • 查询工资大于12000的员工姓名和工资
 SELECT last_name, salary FROM employees WHERE salary > 12000;
  • 查询员工号为176的员工的姓名和部门号
SELECT last_name, department_id FROM employees
WHERE employee_id = 176;
  • 显示表 departments 的结构,并查询其中的全部数据
DESC departments;
SELECT * FROM departments;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值