sql基本操作之增删改查
1. 显示数据库 show databases;
show databases;
2. 显示当前数据库、用户和版本
select current_database(); # hive select database(); #mysql select user(); #显示当前用户
select version(); #版本
3. 创建/删除数据库
create database db_name;
drop database db_name;#删除数据库
4. 选择某个数据库
use db_name;
5. 显示当前数据库下的表
show tables;
6. 创建表 create table
create table if not exists my_test(
id INT UNSIGNED AUTO_INCREMENT,
name_people VARCHAR(40) NOT NULL,
submission_time DATETIME,
PRIMARY KEY(id)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
7. 描述表结构DESC或者DESCRIBE、show columns from
DESC my_test;
SHOW COLUMNS FROM my_test; #显示表结构

8. 插入数据 insert into
INSERT my_test(
id,
name_people,
submission_time
)
VALUES
(1, 'Mary', NOW());
9 .查询 select
select * from my_test;
select name_people from my_test;
select name_peole from my_test where id=1;

10. 删除一条记录 delete
delete from my_test where id=1;
11. 删除表中的所有记录,但是保存原来的表结构
delete from my_test;
12. 更新表的某一列 update
UPDATE my_test SET name_people = '陛下' WHERE id=1
13. 更新多列数据,用 ',' 逗号隔开
UPDATE my_test SET name_people = '将军', submission_time = NOW() WHERE id=1
14. 增加新列 alter,然后update
ALTER table my_test add name_adress VARCHAR(50) not null;
update my_test set name_adress='北京';

15. 复制另一张表的数据和表结构,来新建表 create,使用as关键词
CREATE TABLE my_test_copy AS SELECT * FROM my_test;
SELECT * from my_test_copy;

16. 删除表
drop table table_name;
17. 增加主键,需要先删除原来的主键,否则会报错:[Err] 1068 - Multiple primary key defined
#增加主键
alter table my_test add phone_number VARCHAR(30) not null;
update my_test set phone_number=123456789;
alter table my_test add primary key (phone_number); #[Err] 1068 - Multiple primary key defined,需要先删除原来的主键
18. 删除主键,删除主键出现:[Err] 1075 - Incorrect table definition; there can be only one auto column and it must be defined as a key
alter table my_test drop primary key;
#一般的error:[Err] 1075 - Incorrect table definition; there can be only one auto column and it must be defined as a key
# 表示自增列只能有1列,且这列必须为key,也就是建表的时候,如果是自增列,必须用primary key标识
# 例如:
create table if not exists my_test(
id INT UNSIGNED AUTO_INCREMENT,
name_people VARCHAR(40) NOT NULL,
submission_time DATETIME,
PRIMARY KEY(id)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
#出现错误的原因是:主键是自增属性,不能直接删除
19. 建立一个新表,但是主键不设置为自增属性,然后就可以删除主键
create table if not exists my_test_key(
id INT UNSIGNED,
name_people VARCHAR(40) NOT NULL,
submission_time DATETIME,
PRIMARY KEY(id)
)ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT my_test_key(
id,
name_people,
submission_time
)
VALUES
(1, 'Tom', NOW()); show keys from my_test_key; #显示主键 alter table my_test_key drop primary key; show keys from my_test_key; #显示主键

20. 建立索引 create index
create index index_one on my_test_key(submission_time);

21. 建立唯一索引 create unique index
create unique index index_two on my_test_key(name_people);

22. 显示索引 show index
show index from my_test_key; #显示索引,my_test_key属于表名
23. 显示主键 show keys
show keys from my_test_key; #显示主键,my_test_key属于表名
24. 删除索引 drop index
drop index index_one on my_test_key;
alter table my_test_key drop index index_two;
#欢迎交流
sql基本操作之增删改查的更多相关文章
- Batis-iBatis基本操作(增删改查)
Batis-iBatis基本操作(增删改查) 时间 2014-04-10 17:55:20 CSDN博客 原文 http://blog.csdn.net/mazhaojuan/article/de ...
- 使用java对sql server进行增删改查
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...
- 四种简单的sql语句(增删改查语句)
四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 dele ...
- mysql 的基本操作总结--增删改查
本文只是总结一下mysql 的基本操作,增删改查,以便忘记的时候可以查询一下 1.创建数据库 语法:CREATE DATABASES 数据库名; 例子: CREATE DATABASES studen ...
- dml语句就是你常写的sql语句,增删改查
dml语句就是你常写的sql语句,增删改查
- SQL总结之增删改查
SQL语句增删改查(总结) 一.增:有2种方法 1.使用insert插入单行数据: 语法:insert [into] <表名> [列名] values <列值> 例:ins ...
- 常见 SQL语句使用 增删改查
一.常见的增删改查(一).查:1.SELECT 列名称 FROM 表名称,其中列名可以是多个,中间用豆号分开,如SELECT LastName,FirstName FROM Persons: 2.SE ...
- python连接MySQL pymysql模块,游标,SQL注入问题,增删改查操作
pymysql模块 pymysql是用python控制终端对MySQL数据库进行操作的第三方模块 import pymysql # 1.连接数据库 client = pymysql.connect( ...
- SQL -------- 简单的增删改查
sql 结构化查询语言,一种ansi 的标准计算机语言,为了访问数据库 可以做什么:可以对数据库 和表进行创建于删除, 对表里面的数据进行增删改查. 也可以创建存储过程和视图,对表设置权限 RDBM ...
随机推荐
- docker进入容器内部执行命令
[root@bogon ~]# docker ps -l CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 38a2cae4c32f jenk ...
- Java基础教程:多线程杂谈——Volatile
Java基础教程:多线程杂谈——Volatile 引入Volatile Java语言提供了一种稍弱的同步机制,即Volatile变量,用来确保将变量的更新操作通知到其他线程.当把变量声明为Volati ...
- Tools - Summary List
通用 PicPick:https://picpick.app/zh/ Q-Dir:http://www.softwareok.com/?Download=Q-Dir 7-Zip:https://www ...
- RabbitMQ官方教程二 Work Queues(GOLANG语言实现)
RabbitMQ官方教程二 Work Queues(GOLANG语言实现) 在第一个教程中,我们编写了程序来发送和接收来自命名队列的消息. 在这一部分中,我们将创建一个工作队列,该队列将用于在多个wo ...
- 【C/C++开发】C语言实现函数可变参数
函数原型: int printf(const char *format[,argument]...) 返 回 值: 成功则返回实际输出的字符数,失败返回-1. 函数说明: ...
- BP神经网络设计常用的基本方法和实用技术
尽管神经网络的研究和应用已经取得巨大成功,但在网络的开发设计方面至今仍没有一套完善的理论做指导,应用中采取的主要设计方法是,在充分了解待解决问题的基础上将经验与试探相结合,通过多次改进性试验,最终选出 ...
- C++ 枚举定义
我们在平常的编程中,时常需要为一些属性定义一组可以选择的值,比如文件打开的状态可能会有三种:输入 输出和追加 我们一般情况下记录这些状态是让每一个状态和一个常数相对应 比如 ; ; ; 这个方法虽 ...
- socket编程(二)
TCP下粘包问题 两种情况下会发生粘包. 1.发送端需要等缓冲区满才发送出去,造成粘包(发送数据时间间隔很短,数据了很小,会合到一起,产生粘包) 发送方:AB #其实放在缓存里没发送 发送方:B #其 ...
- K8S从入门到放弃系列-(13)Kubernetes集群mertics-server部署
集群部署好后,如果我们想知道集群中每个节点及节点上的pod资源使用情况,命令行下可以直接使用kubectl top node/pod来查看资源使用情况,默认此命令不能正常使用,需要我们部署对应api资 ...
- (3)Spring Boot日志
文章目录 选择哪一种日志框架 日志的使用 Spring Boot 日志使用 选择哪一种日志框架 市面上日志门面有: JCL(Jakart Commons Logging) .SLF4J(Simple ...