MySQL回顾(一)数据库操作、表操作、数据操作(增删改)

  • 一、对数据库的操作
  • 创建数据库
    create database 数据库名;
    设置编码:create database 数据库名 character set 编码方式;
  • 查看数据库
    查看所有数据库:show databases;
    查看某个数据库的编码方式:show create database 数据库名;
  • 删除数据库
    drop database 数据库名;
  • 其他数据库操作命令
    切换数据库:use 数据库名;
    查看正在使用的数据库:select database();
  • 二、对表的操作
  • 创建表
    create table 表名(
    字段名 类型(长度) [约束],
    字段名 类型(长度) [约束]
    );
    单表约束:
    主键约束:primary key,要求被修饰的字段唯一和非空
    唯一约束:unique,要求被修饰的字段唯一
    非空约束:not null,要求被修饰的字段非空
  • 查看表
    查看数据库中所有表:show tables;
    查看表的结构:desc 表名;
  • 删除表
    删除一张表:drop table 表名;
  • 修改表
    添加一列:alter table 表名 add 字段名 类型(长度)约束;
    修改列的类型(长度和约束):
    alter table 表名 modify 要修改的字段名 类型(长度) 约束;
    修改列的列名:alter table 表名 change 旧列名 新列名 类型(长度) 约束;
    删除列:alter table 表名 drop 列名;
    修改表名:rename table 表名 to 新表名;
    修改表的字符集:alter table 表名 character set 字符集;
  • 三、对数据库表记录操作
  • 插入记录:
    insert into 表名(列名1, 列名2, 列名3, …) values(值1, 值2, 值3, …);
    insert into 表名 values(值1, 值2, 值3, …);
  • 插入数据中文乱码问题解决办法:
    1. 直接修改数据库安装目录中my.ini文件第57行:default-character-set=utf-8
    2. set names gbk;(推荐)
  • 更新记录:
    不带条件的:update 表名 set 列名1=值1, 列名2=值2…;(会将该列所有记录修改)
    带条件的:update 表名 set 列名1=值1, 列名2=值2… where…;
  • 删除记录:
    delete from 表名 [where 条件];
    注意:delete操作不会重置自增长的序号
    面试题: delete、truncate和drop的区别?
    truncate删除表中数据,再插入时自增长id又从1开始。
    delete删除表中数据,可以加where字句。
    drop删除表中数据和表结构。
    (1)delete语句执行删除的过程是每次从表中删除一行,并且同时将该行的 删除操作作为事务记录在日志中保存以便进行进行回滚操作。truncate table会直接删除表,并创建一个与原表结构相同的表,所以自增长id会重置。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。
    (2) 表和索引所占空间。当表被truncate后,这个表和索引所占用的空间会恢复到初始大小,而delete操作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。
    (3) 一般而言,执行速度:drop > truncate > delete
    (4) 应用范围。truncate 只能对table;delete可以是table和view
    (5) truncate 和delete只删除数据,而drop则删除整个表(结构和数据)。
    (6) truncate与不带where的delete :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。
    (7) delete语句为DML(data maintain Language),这个操作会被放到 rollback segment中,事务提交后才生效。如果有相应的 tigger,执行的时候将被触发。
    (8) truncate、drop是DLL(data define language),操作立即生效,原数据不放到 rollback segment中,不能回滚,即使配合了事务,也无效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值