SQL的一些常用语句

创建类

CREAT DATABASE <数据库名>;

该方法创建一个数据库,当要使用一个数据库的时候,使用指令:

USE <数据库名>;

查看当前正在使用的数据库可以使用:

SHOW STATUS;
CREAT TABLE <表名>(
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
PRIMARY KEY (<主键><, <主键>...> )
);

该方法在正在use的数据库中创建一张表。列名,也叫字段名,从Excel的术语中说就是表头的意思。列名后要指定列的数据类型,如INTVARCHAR(10)等等。

列参数还有:

NOT NULL  不允许使用NULL
AUTO_INCREMENT 自动+1(在INSERT数据的时候,这一列上的值自动+1)
等等...

其中,如果你设置了某一列为AUTO_INCREMENT的时候,还要使用PRIMARY KEY (<主键><, <主键>...> )将其设置为主键。多个主键使用,分割。

特别提示:括号内所包含的最后项的后面不需要逗号。

如:

CREAT TABLE <表名>(
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
);

是错误的,应该写为

CREAT TABLE <表名>(
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>,
<列名> <数据类型> <列参数...>
);

显示类

SHOW DATABASES;

查看当前所拥有的所有数据库库名可以使用该语句。

特别注意:是DATABASES而不是DATABASE,创建数据库的时候是DATABASE而不是DATABASES。

SHOW TABLES;

查看当前USE的数据库中所有表表名可以使用该语句。

SELECT * FROM <表名>;

使用该语句,可以查看数据表中所有的数据。关于SELECTFROM语句将在后面介绍。

注意:当数据表为空的时候,会显示 Empty set (0.00 sec)

删除类

DROP DATABASE <数据库名>;

该语句可以删除数据库。

DROP TABLE <表名>;

该语句可以删除当前USE的数据库中的数据表。

注:关于删除表中数据请参考后文

数据表操作

插入数据

INSERT INTO <表名> (<列名1>, <列名2>...) VALUES (<数据1>, <数据2>),(<数据1>, <数据2>)...;

该语句在数据表中新建一行,其中<列名1>的插入<数据1>,<列名2>的插入<数据2>,其他列插入NULL,如果设置了自增,则自己加一。

一次性插入多条数据使用,间隔。

注意,设置了NOT NULL的列不可以插入NULL。如果无特殊要求,应该总保持NOT NULL的设置,因为NULL会影响性能。

查询数据

SELECT <列名>,<列名>... FROM <表名>;

该语句会显示数据表中指定列的数据。当然,如果你想显示所有的数据,你可以使用SELECT * FROM <表名>,值得注意的是*并不是正则表达式的意思。

WHERE、LIKE和REGEXP子句

FROM语句后面可以接WHERE字句,用于筛选。

SELECT xxx FROM <表名> WHERE <条件表达式>,<条件表达式>...

多个条件表达式之间使用,分割。id = 10表示筛选出id列值10的数据。同时还支持>,>=等符号。

SELECT name class FROM <student> WHERE id >= 10

如上表示,输出表studentid >= 10的数据的nameclass

LIKE子句

表达式还支持模糊匹配。其中%匹配一个或以上的任意字符,_匹配一个任意字符。如:"%2%"可以匹配"123",或者"s123"等等,但是不能匹配"23"或者"12"或者"2"_2_可以匹配"123"但不可以匹配"0123"

SELECT name class FROM <student> WHERE name like "王%"

如上筛选出所有name的数据,并输出他们的nameclass

REGEXP子句

REGEXP用于正则匹配,其比LIKE更加灵活。

SELECT name class FROM <student> WHERE name like "王.+"

如上筛选出所有name的数据,并输出他们的nameclass

ORDER BY子句

ORDER BY子句可以用于排序数据。注意:数据本身的顺序其实没有改变。

SELECT name class FROM <student> ORDER BY <排序语句>,<排序语句>...

其中,排序语句由列名和排序方式组成:<列名> <排序方式>。多个排序语句用,分隔。

排序类型有:ASC正向排序[默认],DESC反向排序。

UNION

UNION可以合并多个SELECT的结果。和并方式有两种,一种是交集DISTINCT(默认),一种是并集ALL

SELECT <列名>,<列名> FROM <表名> <WHERE、ORDER BY等子句> UNION <方式> SELECT <列名> FROM <表名>,<列名> <WHERE、ORDER BY等子句> UNION <方式> ...

交集:当输出两个数据完全一样(每一列上的数据)的时候,这组数据只会显示一次。

并集:就是把数据全部合并到一起输出。

修改数据

可以使用UPDATE来修改表中的数据。

UPDATE <表名> SET <列名> = <新值>, <列名> = <新值> <WHERE子句>

注意:WHERE子句用来指定修改那些数据,如果不使用WHERE子句,则会修改数据表中所有的数据。

删除数据

可以使用DELETE来修改表中的数据。

DELETE FROM <表名> <WHERE子句>

注意:WHERE子句用来指定删除那些数据,如果不使用WHERE子句,则会删除数据表中所有的数据。

SQL语句(mysql)「一」的更多相关文章

  1. 全国省市级联数据sql语句 mysql版

    全国省市级联数据sql语句 mysql版 --省级 provincial create table provincial ( provincialID int, provincialName ), p ...

  2. JDBC进阶之PreparedStatement执行SQL语句(MySQL)

    一.什么是PreparedStatement           参阅Java API文档,我们可以知道,PreparedStatement是Statement的子接口(如图所示),表示预编译的 SQ ...

  3. sql语句 MySQL

    1.操作数据库 (1)创建数据库 CREATE  DATABASE  [IF NOT EXISTS] db_name [create_specification [, create_specifica ...

  4. 50个SQL语句(MySQL版) 建表 插入数据

    本学期正在学习数据库,前段时间老师让我们做一下50个经典SQL语句,当时做的比较快,有一些也是百度的,自我感觉理解的不是很透彻. 所以从本篇随笔开始,我将进行50个经典SQL语句的复盘,加深理解. 答 ...

  5. php 执行大量sql语句 MySQL server has gone away

    php 设置超时时间单位秒 set_time_limit(3600);   php 设置内存限制ini_set('memory_limit', '1024M');   mysql服务端接收到的包的大小 ...

  6. mysql用户管理 常用sql语句 mysql数据库备份恢复

     

  7. 50个SQL语句(MySQL版) 问题十四

    --------------------------表结构-------------------------- student(StuId,StuName,StuAge,StuSex) 学生表 tea ...

  8. 50个SQL语句(MySQL版) 问题十三

    --------------------------表结构-------------------------- student(StuId,StuName,StuAge,StuSex) 学生表 tea ...

  9. 50个SQL语句(MySQL版) 问题十二

    --------------------------表结构-------------------------- student(StuId,StuName,StuAge,StuSex) 学生表 tea ...

  10. 50个SQL语句(MySQL版) 问题十一

    --------------------------表结构-------------------------- student(StuId,StuName,StuAge,StuSex) 学生表 tea ...

随机推荐

  1. 记一次 .NET 某仪器测量系统 CPU爆高分析

    一:背景 1. 讲故事 最近也挺奇怪,看到了两起 CPU 爆高的案例,且诱因也是一致的,觉得有一些代表性,合并分享出来帮助大家来避坑吧,闲话不多说,直接上 windbg 分析. 二:WinDbg 分析 ...

  2. open3d -- voxel_down_sample

    官网文档 parameter: Input: open3d.geometry.Pointcloud点云类 voxel_size: 体素单位长度 Return: 处理后的点云类 Description: ...

  3. 【vulnhub】——DC-9靶机

    [vulnhub]--DC-9靶机 1. 主机发现 扫描kali主机C段(Kali和DC-9主机在同一个网关下): 发现主机为192.168.108.146,进行详细端口扫描: 可以看到靶机开了一个s ...

  4. multiset用法汇总

    c++语言中,multiset是<set>库中一个非常有用的类型,它可以看成一个序列,插入一个数,删除一个数都能够在O(logn)的时间内完成,而且他能时刻保证序列中的数是有序的,而且序列 ...

  5. 为何 DevOps 会给开发人员带来压力和倦怠?

    企业正在享受 DevOps 实施带来的好处,但这也是有代价的.开发人员需要承担额外的责任,可能会导致他们感到疲惫不堪.因此我们可以采取一些方法来确保 DevOps 工程师的满意度. DevOps 的支 ...

  6. 洛谷P3612(递归)

    题目描述 The cows are experimenting with secret codes, and have devised a method for creating an infinit ...

  7. 开发现代化的.NetCore控制台程序:(3)将nuget包发布到GitHubPackages

    前言 上一篇文章已经把项目模板的nuget包发布到了 nuget 的官方源了,其实还可以发布到其他源,比如 GitHub ,本文记录一下发布到 GitHub Packages 的过程. 注意:本文建立 ...

  8. Ubuntu 20.04 查看内存信息

    输入命令 dmidecode -t memory 输出如下: # dmidecode 3.2 Getting SMBIOS data from sysfs. SMBIOS 2.8 present. H ...

  9. rust程序设计(5)结构体相关练习题| 附带解答

    题目 基础结构体练习: 创建一个名为Person的结构体,包含name(字符串类型)和age(整数类型)两个字段. 写一个函数,接收一个Person实例作为参数,并打印出这个人的名字和年龄. 结构体方 ...

  10. 基于OpenAi通用特定领域的智能语音小助手

    无穷尽的Q&A 钉钉...钉钉... 双双同学刚到工位,报销答疑群的消息就万马纷沓而来.她只能咧嘴无奈的摇摇头.水都还没有喝一口就开始"人工智能"的去回复.原本很阳光心情开 ...