SQL 是 Structure Query Language(结构化查询语言)的缩写,它是关系模型数据库的一门应用语言。经长期发展,SQL语言标准日趋完善,SQL已然成为一种十分受欢迎的多平台交互底层会话语言。
SQL语句主要可以划分为以下三个类别:
接下来将会依次对SQL三种类别标准和语法进行介绍,同时基于MySQL进行相关实例演示,并对MySQL部分扩展语法稍作说明,以此更好地熟悉掌握SQL语句并为今后的学习和工作打下基础。
在系统服务或命令行窗口启动MySQL服务后,在命令行输入以下命令来连接MySQL服务器
C:\Users\username>mysql -uroot –p
其中,命令的’mysql’代表客户端命令,’-u’后接’root’表示身份为数据库根用户,而’-p’表示需输入密码
具体如下图所示:
连接成功后将提示进入欢迎界面,此界面主要显示了以下几个内容:
DDL是数据定义语言的缩写,主要用来对数据库内部对象进行创建、删除和修改等操作,它大多数是由DBA(DataBase Administrator,数据库管理员)使用,而开发人员一般很少使用。根据操作对象的不同,可以划分为数据库操作和数据表操作。数据库是数据存放的容器,而数据表则是数据所对应的结构的描述。
基本语法:CREATE DATABASE dbname;
例(创建一个名为example的数据库)
执行后得到了“Query OK, 1 row affected (0.18 sec)”消息,它表示此命令执行成功,只影响了一行记录(因为只创建1个数据库),耗时0.18秒。
如果试图创建一个已存在的同名数据库,则会出现如下错误提醒:
例(试图创建一个已经存在的同名数据库)
基本语法:SHOW DATABASES;
例(查看系统中已存在的数据库)
从图中可以看到,系统目前共有5个数据库,除了我们刚刚创建的example数据库,其他都是系统自带创建的。其中,information_schema用于存储系统数据库对象信息,mysql用于存储用户权限信息,performance_schema用于收集数据库服务器性能参数,sys包含了一系列存储过程、自定义函数以及视图等以帮助获取系统对象信息,另外其实系统会自动创建test测试数据库(图中没有显示是因为之前无意中删除了)
基本语法:USE dbname;
例(选用example数据库)
基本语法:SHOW TABLES;
例(查看test1数据库中数据表)
基本语法:DROP DATABASE dbname;
例(删除test1数据库)
基本语法:
CREATE TABLE tablename(
column_name_1 column_type_1 constraints,
column_name_2 column_type_2 constraints,
…
column_name_n column_type_n constraints
);
其中column_name为表中属性列的名称,column_type为此属性的数据类型,constraints表示对属性的约束条件(如此属性是否可取空值,属性取值范围等)
例(在example数据库中创建一个Student学生表)
基本语法:DESC tablename;
例(查看Student表)
这种查看表有一个弊端就是显示的内容不全面,如果要显示出完整信息,则可以通过‘SHOW CREATE TABLE tablename \G’来查看表(注意此处‘\G‘不等同于’\g‘,两者均为显示相关信息,但前者会以垂直形式显示,界面更友好)
例(查看Student表的全部信息)
基本语法:DROP TABLE tablename;
例(删除temp表)
基本语法:ALTER TABLE tablename MODIFY [COLUMN] column_definition [FIRST|AFTER column_name];
其中’MODIFY’为修改关键字,’column_definition’为要修改的属性列对象新定义,’[FIRST|AFTER column_name]’表示修改后列存放的位置,’FIRST’为存放在第一行,’AFTER column_name’为存放在某一列后面,若未选择位置则默认保持不变,之后操作语法说明类似
例(将Student表中Sno属性数据类型修改为char(12))
基本语法:ALTER TABLE tablename ADD [COLUMN] column_definition [FIRST|AFTER column_name];
例(为Student表新增一个Sgrade属性字段)
基本语法:ALTER TABLE tablename DROP [COLUMN] column_name;
例(删除Student表中Sgrade属性字段)
基本语法:ALTER TABLE tablename CHANGE [COLUMN] old_column_name column_definition [FIRST|AFTER column_name];
例(将Student表中Sno改名为Sid)
这里要注意的是,CHANGE与MODIFY均可以修改表属性字段,但CHANGE还可以修改名称,而MODIFY不能
基本语法:ALTER TABLE tablename RENAME [TO] new_tablename;
例(将Student表改名为stu)
本次SQL基础使用入门(一)主要介绍了SQL基本概述及SQL语句三个类别划分,并详细讲述了SQL语句第一个类别——DDL数据定义语言及其使用的基本语法,同时结合演示说明了对数据库和数据表两大对象的基本操作。
原文:https://www.cnblogs.com/Unikfox/p/9136475.html