SQL语句使用

一:sql语句

1.什么是SQL语句?

是访问和操作关系数据库的标准语言。只要是关系数据库,都可以使用 SQL 进行访问和控制。
image

  • 库>表>记录
    image

二:基本SQL语句之库操作

增
create database 数据库名称;

查
1.查看所有
show databases;

2.查看单个库
show create database 数据库名称;

改
1.修改字符编码
alter database 数据库名称 charset='编码';

删
1.删除数据库
drop database 数据库名称;

三:基本SQL语句之表操作

1.查看当前所在库名称

select database();

2.切换数据库

use 数据库名称;

增
1.创建表一定要给字段(每个表最少要有一个 字段=列)
create table 表名(字段名称 字段类型)


查
1.查看当前库下面所有表名称
show tables;

2.查看指定表的详细信息(创建语句)
show create table 表名;

3.可以简写desc(查看表结构)
describe 表名;

改
1.修改表名
alter table 表名 rename 新表名;

删
1.删除表名
drop table 表名;

四:基本SQL语句之记录操作

操作记录之前肯定得先有库和表

1.先创建库
create database db1;
2.切换到库内
use db1;
3.创建表
create table t1(id int,name varchar(32));  # 存储最多32个字符
4.查看表结构
desc t1

image

增
1.表内插入单个数据
insert into t1 values(1,'jason');
表内插入单个元素格式
insert into 表名 values('按照字段顺序一一传值(逗号隔开)');

2.表内插入多个数据
insert into t1 values(1,'jason'),(2,'tony'),(3,'data');
insert into 表名 values(...),(...),(...);

查
1.查询指定表内所有字段数据(*=所有)
select * from 表名;

2.指定查询表内多个字段(也可以通过库名.表名跨库)
select 字段名1,字段名2 from 表名;

3.解决查询字段过多问题
select * from mysql.user\G;
如果字段过多导致展示错乱 还可以使用\G结尾分行展示

改
1.将表名ti内,id为1的name字段从原来的jason修改成jasonSB
update t1 set name='jasonSB' where id='1';
格式:
update 表名 set 字段名=新值 where 字段名=存在的值/条件  

where		: 筛选条件

删
1.删除指定表内字段对应的值
delete from 表名 where 字段名=存在的值  

注意:不加条件会全部删除

image

五:创建表的完整语法

create table 表名(
	字段名1 字段类型(数字) 约束条件,
    字段名2 字段类型(数字) 约束条件,
    字段名3 字段类型(数字) 约束条件
);

数字 : 表示字段的长度
约束条件 : 基于字段类型之上的额外约束

  • 注意事项
1.字段名和字段类型是必须的 数字和约束条件是可选
2.约束条件可以有多个
3.最后一个字段结尾不能有逗号	(不容易发现)

六:操作表的SQL语句(进阶版)

1.添加表字段
1.表内添加字段pwd与指定类型 
alter table t9 add pwd int;

2.表内指定添加hobby字段到age字段后面
alter table t9 add hobby varchar(32) after age;

3.表内指定添加字段nid 类型int 到字段最前面
alter table t9 add nid int first;
2.删除表字段
alter table t9 drop nid;
3.修改表名称
1.修改表名称
alter table t1 rename t2;

2.关键字(rename)修改表名称
rename table t1 to t123;  

3.同时修改多个表名称
rename table t2 to t20,
    		t3 to t30,
        	t4 to t40;
4.修改字段名和字段类型
1.modify只能修改字段类型
alter table t9 modify age tinyint;

2.change能修改字段名和类型
alter table t9 change pwd password int;  

七:复制表

查询语句执行的结果也是一张表,可以看成虚拟表
1.复制表结构+记录 (key不会复制: 主键、外键和索引)
create table new_service select * from service;

解释:
    new_service复制service内的结构与记录(key不复制)
    
2.只拷贝表结构(不包含key)
create table new1_service select * from service where 1=2;  

解释:
    new1_service复制service内的结构,条件成立是复制记录,不成立不复制记录
    
3.拷贝结构包含各种key(不包含记录)
create table t4 like employees;

解释:
    拷贝结构包含各种key,不包含记录,关键字 like
posted @ 2022-01-25 20:02  [OJBK]  阅读(41)  评论(0编辑  收藏  举报