Mysql系列基础篇-SQL分类(DDL)

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 表名;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值