## 常用sql语句整理:mysql
1. 增
– 增加一张表
“`
CREATE TABLE `table_name`(
…
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
“`
– 增加记录
“`
INSERT INTO `your_table_name`(`column_name`)
VALUES
(‘your_value_one’),
(‘your_value_two’);
“`
– 增加字段
“`
ALTER TABLE `your_table_name`
ADD `your_column_name` …
AFTER `column_name`;
“`
– 增加索引
+ 主键
“`
ALTER TABLE `your_table_name`
ADD PRIMARY KEY your_index_name(your_column_name);
“`
+ 唯一索引
“`
ALTER TABLE `your_table_name`
ADD UNIQUE your_index_name(your_column_name);
“`
+ 普通索引
“`
ALTER TABLE `your_table_name`
ADD INDEX your_index_name(your_column_name);
“`
+ 全文索引
“`
ALTER TABLE `your_table_name`
ADD FULLTEXT your_index_name(your_column_name);
“`
2. 删
– 逐行删除
“`
DELETE FORM `table_name`
WHERE …;
“`
– 清空整张表
“`
TRUNCATE TABLE `your_table_name`;
“`
– 删除表
“`
DROP TABLE `your_table_name`;
“`
– 删除字段
“`
ALTER TABLE `your_table_name`
DROP `column_name`;
“`
– 删除索引
“`
ALTER TABLE `your_table_name`
DROP INDEX your_index_name(your_column_name);
“`
3. 改
– 变更数据
“`
UPDATE `table_name`
SET column_name=your_value
WHERE …;
“`
– 变更字段
“`
ALTER TABLE `your_table_name`
CHANGE `your_column_name` `your_column_name` …(变更);
“`
– 变更字段值为另一张表的某个值
“`
UPDATE `your_table_name`
AS a
JOIN `your_anther_table_name`
AS b
SET a.column = b.anther_column
WHERE a.id = b.a_id…;
“`
4. 查
– 普通查询
“`
SELECT `column_name_one`, `column_name_two`
FROM `table_name`;
“`
– 关联查询
“`
SELECT *
FROM `your_table_name`
AS a
JOIN `your_anther_table_name`
AS b
WHERE a.column_name = b.column_name…;
“`
– 合计函数条件查询:WHERE 关键字无法与合计函数一起使用
“`
SELECT aggregate_function(column_name)
FROM your_table_name
GROUP BY column_name
HAVING aggregate_function(column_name)…;
“`
– 同一个实例下跨库查询
“`
SELECT *
FROM database_name.your_table_name
AS a
JOIN another_database_name.your_another_table_name
AS b
WHERE a.column_name = b.column_name…;
“`
5. 复制一张表结构
“`
CREATE TABLE `your_table_name`
LIKE `destination_table_name`;
“`
6. 完全复制一张表:表结构+全部数据
“`
CREATE TABLE `your_table_name`
LIKE `destination_table_name`;
INSERT INTO `your_table_name`
SELECT *
FROM `destination_table_name`;
“`
—
### 附录:mysql常用命令
– 登陆: mysql -h host -u username -p
– 列出数据库:SHOW DATABESES;
– 列出表:SHOW TABLES;
– 列出表结构:DESC table_name
– 使用一个数据库:USE database_name;
– 导入:source ‘file’;
– 导出:mysqldump -h 127.0.0.1 -u root -p “database_name” “table_name” –where=”condition” > file_name.sql;
– 查看慢日志:mysqldumpslow -s [c:按记录次数排序/t:时间/l:锁定时间/r:返回的记录数] -t [n:前n条数据] -g “正则” /path
– 新增用户: insert into `user`(`Host`, `User`, `authentication_string`) value(‘localhost’, ‘username’, password(‘pwd’))
### mysql 5.7 新增用户
“`
// 插入新用户
insert into mysql.user(Host, User, authentication_string, ssl_cipher, x509_issuer, x509_subject
value(‘localhost’, ‘username’, password(‘password’), ”, ”, ”);
// 数据库授权
grant all privileges on dbname.name.* to username@localhost identified by ‘password’;
// 刷新权限信息
FLUSH PRIVILEGES;
“`
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/113828.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...