SQL分类
- DDL(数据定义语言)
数据库和数据表的创建、删除和修改(create、drop、alter) - DML(数据操作语言)
操作数据库中存储的数据(insert、update、delte) - DQL(数据查询语言)
对数据库中存储的数据进行查询(select) - DCL(数据控制语言)
用来定义访问的权限和安全级别,对用户的创建,及授权
DDL
创建数据库
create database if not exists 数据库名 character set utf8 collate utf8_general_ci;
修改数据库
修改数据库的名(有三种方式)
第一种
rename database oldname to newname;
第二种
1.创建需要改成新名的数据库
2.mysqldum 导出要改名的数据库
3.删除原来的旧库(确定是否真的需要)
当然这种方法虽然安全,但是如果数据量大,会比较耗时
第三种
#/bin/bash
#假设test是old库,new_test是new库,这种方法即安全,又快速
mysql -uxxx -pxx -e 'create database if not exists new_test'
mysql -uxxx -pxxx -Nse "select table_name from information_schema.TABLES where TABLE_SCHEMA='test'" > list_table.txt
for table in $(cat list_table.txt)
do
echo $table
mysql -uxxx -pxxx -e "rename table test.$table to new_test.$table"
done
-N:不显示列名
-s:忽略边框
-e:执行sql
修改数据库的编码
alter database 数据库名 character set 字符集名称;
修改mysql数据库默认的编码格式
临时修改
set character_server=utf8;
永久性生效
命令:vi /etc/my,cnf
在[client ]下面加入
default-character-set=utf8
在[ mysqld ] 下面加
character_set_server=utf8
init_connect=`SET NAMES utf8`
删除数据库
drop database 数据库名 if exists;
其他有关数据库的操作
查询当前所有的数据库
show databases;
查询当前所在的数据库
select database();
查询数据库的编码格式
show variables like 'character%';
查询数据的排序规则
show variables like 'collation%';
创建数据表
create table 表名(
字段名 字段类型,
字段名 字段类型,
字段名 字段类型,
......);
复制表
create table 表名 like 被复制的表名;(复制的只是表结构)
create table 表名 (select * from 被复制的表);(复制的是表的全部内容)
修改数据表
修改表的字符集
alter table 表名 character set 字符集名称;
修改数据表名
rename table old_table to new_table;
alter table old_table rename new_table;
修改列的名称和类型
alter table 表名 change 列名 新列名 新数据类型;
修改列的类型
alter table 表名 modify 列名 新数据类型;
增加列
alter table 表名 add 列名 数据类型;(这一列在表的最后一列位置)
alter table 表名 add column 新列名 数据类型 after 某一列的列名 ;(在某一列后面添加一列)
alter table 表名 add column 新列名 数据类型 first ;(在表的最前面添加一列)
删除列
alter table 表名 drop 列名;
删除数据表
drop table 表名;
truncate table 表名;(保留表而将所有数据删除,如果和事务无关,用truncate即可);
delete from 表名;(如果和事务有关,或者想触发trigger(触发器),还是用delete,不加where条件,默认删除所有数据,另外删除数据后磁盘空间不会降低,需要清理表内部的碎片)
其他有关数据表的操作
查看当前库中的所有表
mysql> show tables;
查看表结构
desc 表名;