入门必学的sql语句

1.sql简介

数据存放在数据中,SQL是用于访问和处理数据库的标准的计算机语言,SQL是

Structured Query Language 的缩写,是指结构化查询语言。

特点:

  1. 简单易学
  2. 功能强大
  3. 只说明要做什么,不说明如何做
  4. 标准化,几乎所有的关系数据库都通用
  5. 不区分大小写

在黑窗口打开MySQL的语句:

mysql -u root -p


如果你已经装好环境变量可以直接用:

2.查看数据

show databases;查看所有数据库
show tables;查看所有表
desc 表名;查看表结构

3.create创建

create table创建表
指定数据库create table 表名(字段名1.数据类型(长度),字段2.数据类型(长度),....);
创建数据库
create database 数据库名
设置字符集为utf-8
charset utf-8

4.insert插入
insert语句用于向表中插入新记录,它有两种写法:
第一种写法:为表中的所有字段添加值时不需要字段名称,但要确保值的顺序与表中的字段顺序相同,语法:
insert  into 表名 values(字段1的值,字段2的值,字段3的值,......);
第二种写法:为指定的字段插入数据时,要把字段名和字段值列出,并一 一对应,语法:
insert into 表名(字段1,字段2,字段3,......)valuse(字段1的值,字段2的值,字段三的值,......);

5.primary key表的主键
主键的作用
主键的全称是主键约束,表的主键由表中的一个字段或多字段组成,主键唯一代表表中一条记录,关系数据库中通常每个表都有一个主键
没有主键的表通常是不严谨的设计的,主键的特点:
每个表中只能定义一个主键
主键值必须唯一标识表中的每一记录,且不能为null,即表中不可能存在有相同主键值的两条记录。
一个字段名只能在联合主键字段中出现一次。
联合主键不能包括不必要的多余字段,当把联合主键的某一字段删除后,剩下的字段不能唯一代表一条记录

6.select查询
select的写法
查询表中所有的字段:
select * from表名;
查询表中指定的字段:
select 字段1,字段2 from 表名;

7.distinct去重复值
distinct 的用法
同一字段中可能会出现重复值,使用关键词distinct可以去掉重复值,用法:
select distinct 字段名  from 表名;

8.where条件过滤
where的用法
如果需要从表中选取指定的数据,可将where子句添加到select语句,语法:
select 字段名 from 表名 where 字段 运算符 值;
where子句中的运算符

  1. 运算符      说明
  2.   =          等于
  3.  <>或!=  不等于
  4.  >          大于
  5.  <          小于
  6.  >=       大于等于
  7.  <=       小于等于

9.like的用法

在where子句中使用like运算符来搜索匹配字符串中的指定模式,百分号(%)

(字段名%)匹配字段名在前面的

(%字段名)匹配字段名在后面

(%字段名%)匹配字段名在中间的

匹配零个,一个或多个字符。语法:

select 字段名  from  表名 where 字段 like 字符串;

10.and和or运算符
and和or 可以用在where子句中把两个或多个条件结合起来,and运算符要求两个条件
都成立;or运算符要求两个条件中只要一个成立即可,语法:
select 字段名 from 表名 where 字段n 运算符 值n  and|or  字段m  运算符 值m;

11.in匹配多个值
in的用法
in运算符是在where子句中指定多个搜索条件可以匹配的值,in运算符实际是多个or条件的合并,语法:
select 字段名 from 表名 where 字段名 in (值1,值2,......);
也可以用 not in去除不需要的值
select 字段名 from 表名 where 字段名 not in (值1,值2,.....);

12.between指定范围
between的用法
between运算符用于选取介于两个值之间的数据范围内的值,这些值可以是数字,字符串或日期,between运算符包括开始和结束值,相当于>=and<=
语法:
select 字段名 from 表名 where 字段名 between 值1 and 值2;
也可以使用not between 选取范围不介于这个之间
select 字段名 from 表名 where 字段名not between 值1 and 值2;

13.order by排序
order by用法
order by用于结果集进行排序,默认按升序(asc)进行排序,也可以指定desc按降序对结果集进行排序,语法:
select 字段名 from 表名 order by 字段1,字段2,....asc|desc;

14.update更新数据
update用法:
update 语句用法更新表中的记录,语法:
update 表名 set 字段1=值1,字段2=值2 ,...where 子句;
注意!:where 子句指定哪些记录需要更新,                                                                                 如果省略where 子句,表中的所有记录都将更新!!!

15.delete删除数据   drop 删除数据库
delete用法
delete语句用于删除表中的记录,语法:
delete from 表名 where 子句;
注意!: where子句指定哪些记录需要删除,如果省略where子句,表中的所有记录都将删除。
            drop 删除数据库
语法:
drop database 数据库名

16.index索引
index的用法
索引可以提高访问数据的速度,创建索引的语法:
create  index  索引名 on表名(字段1,字段2,....)
使用索引时sql语句的语法和不使用索引并没有任何不同,sql语法会自动使用索引提高访问数据的速度

17.view视图
view的用法
视图是基于sql语句的结果集的可视化表,视图中的字段就是来自一个或多个数据库中的真实的表中的字段。
视图总是显示当前的数据,每当用户查询视图时,数据库引擎通过使用sql语句来重建数据
创建视图语法:
create  view 视图名 as select语句;

18.null值
null值的用法
null值代表遗漏的未知数据,它的作用是未知的或不适应的占位符,
如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况插入新记录或更新已有的记录,这意味着该字段将以null值保存,
字段值是否是null的判断不能用=或者<>进行,要用is  null或者is not null进行。

19.字段和表的别名
字段和表的别名用法
作用
在sql语句中可以为表名或字段名指定临时使用的别名(Alisa),别名只在当前的sql语句中生效,它通常比字段名更具有可读性,
别名有以下应用场景;
-字段名长或可读性差时
-涉及多个表,而且多个表中有相同的字段名时
-代表查询函数的结果
别名的语法:
select 字段名 别名 from 表名  别名;

20.join连接
join用法
join连接是基于多表之间的共同字段把它们结合起来查询的一种方法,连接分为以下几种:
内连接(inner join)列出两个表中都存在的记录
左连接(left join)即使没有匹配也列出左表中的所有记录
右连接(right join)即使没有匹配也列出右表中的 所有记录
语法:
select 字段名 from 表1 join 表2 where子句;

21.SubQuery子查询
subquery子查询用法
子查询也称嵌套查询,是一种嵌套在其他sql语句的where 子句中的查询,子查询用于为主查询返回其所需数据,或者对检索数据进行进一步的限制,语法:
select 字段1,字段2,...from 表名 where 字段名 操作符(子查询);

22.sql常用函数
count函数
count函数是统计符合条件的 记录
count(*)统计表中的记录总数
count(字段名)统计指定字段不为null的记录数
max函数
max函数返回所选的最大值,
用法是max(字段名)
min函数
min函数返回所选的最小值,
用法是min(字段名)
avg函数
avg函数返回所选的平均值,
用法是avg(字段名)
sum函数
sum函数返回所选的合计值,
用法是sum(字段名)

23.group by分组
group by分组用法
group by语法用于结合统计函数,根据一个或多个列对结果集进行分组,语法:
select 字段名,统计函数from 表名 where 子句 group by字段名;

24.having过滤
having 过滤分组用法
having子句和where子句类似,都是对查询的结果进行过滤,它们的过滤对象不同,where 子句对被选择的列进行过滤,
而having子句则对group by子句所产生的组进行过滤。句法:select 字段名,统计函数 from 表名子句 group by字段名 having 统计函数 运算符 值;

常用数据类型说明
int整数类型
char(n)字符/字符串,固定长度n
varchar(n)字符/字符串,可变长度,最大长度n
numeric(a,b)精确数据,总位数a,小数点后位数b
date存储年,月,日的值

把这些记下来就可以度过小白阶段了!!!

加油!!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值