首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    [数据库]-基础面试题总结

    drop(丢弃数据): drop table 表名 ,直接将表(表结构和数据)都删除掉,在删除表的时候使用。 truncate (清空数据) : truncate table 表名 ,只删除表中的数据,再插入数据的时候自增长 id 又从 1 开始,在清空表中数据的时候使用。 delete(删除数据) : delete from 表名 where 列名=值,删除某一列的数据,如果不加 where 子句和truncate table 表名作用类似。但是再进行插入的话自增id并不是从1开始,而是接着之前的自增开始。 truncate 和不带 where 子句的 delete、以及 drop 都会删除表内的数据,但是 truncate 和 delete 只删除数据不删除表的结构(定义),执行 drop 语句,此表的结构也会删除,也就是执行 drop 之后对应的表不复存在。

    05

    「mysql优化专题」90%程序员都会忽略的增删改优化(2)

    通常情况下,当访问某张表的时候,读取者首先必须获取该表的锁,如果有写入操作到达,那么写入者一直等待读取者完成操作(查询开始之后就不能中断,因此允许读取者完成操作)。当读取者完成对表的操作的时候,锁就会被解除。如果写入者正在等待的时候,另一个读取操作到达了,该读取操作也会被阻塞(block),因为默认的调度策略是写入者优先于读取者。当第一个读取者完成操作并解放锁后,写入者开始操作,并且直到该写入者完成操作,第二个读取者才开始操作。因此:要提高MySQL的更新/插入效率,应首先考虑降低锁的竞争,减少写操作的等待时间。 (本专题在后面会讨论表设计的优化)本篇,要讲的优化是增删改。

    03

    mysql常用命令

    创建用户 create user “用户名”@“权限” identified by "密码"; 添加权限 grant 权限 on 数据库名.表名 to "用户名"@"登录权限"(IP地址或localhost) identified by "密码"; 更改密码 set password for "用户名"@"登录权限"=password("新密码") 如果当前用户 set password=password("新密码") 回收权限 revoke 赋予的权限 on 数据库.表名 from "用户名"@"登录权限"; 删除用户 drop user "用户名"@"登录权限"; 查询数据库 show databases; 创建数据库 create database 数据库名字; 删除数据库 drop database 数据库名字; 切换数据库 use 数据库 查询数据库有多少表 show tables; 查询表的信息 select * from 表名 查询表结构 desc 表名 创建表 create table 表名(id int auto_increment primary key not null, 字段名字1 类型, 字段名字2 类型, .... ); 删除表 drop table 表名 更新表 alter table 表名 change 原列名 新列名 类型; 添加字段 alter table 表名 add 列名 类型; 删除字段 alter table 表名 drop 列名; 重命名表名 alter table 表名 rename 新表名 数据查询 select 字段名字 from 表名 数据添加 insert into 表名 values(0,值(有多少内容就写多少值)); 缺省添加 insert into 表名 (字段1,字段2)values(值1,值2); 数据更新 update 表名 set 列1=新值 where 条件; 数据删除 delete from 表名 where 条件 外键 定义外键 alter table 表名 内连接查询: 例子: select o.name, t.name from object o inner join teacher t on o.teacherid = t.id; select 表一别名.表一要显示的内容,表二别名.表二要显示的内容(可以继续添加内容,中间使用逗号隔开)from 表一 表一的别名 inner join 表二 表二的别名 on 表一别名.外键=表二别名.表二的主键 左连接查询: select o.name, t.name from object o left join teacher t on o.teacherid = t.id; select 表一别名.表一要显示的内容,表二别名.表二要显示的内容(可以继续添加内容,中间使用逗号隔开)from 表一 表一的别名 inner join 表二 表二的别名 on 表一别名.外键=表二别名.表二的主键 右连接查询: select o.name, t.name from object o right join teacher t on o.teacherid = t.id; select 表一别名.表一要显示的内容,表二别名.表二要显示的内容(可以继续添加内容,中间使用逗号隔开)from 表一 表一的别名 inner join 表二 表二的别名 on 表一别名.外键=表二别名.表二的主键

    02

    MySQL从删库到跑路_高级(一)——数据完整性

    数据冗余是指数据库中存在一些重复的数据,数据完整性是指数据库中的数据能够正确反应实际情况。 数据的完整性是指数据的可靠性和准确性,数据完整性类型有四种: A、实体完整性:实体的完整性强制表的标识符列或主键的完整性(通过唯一约束,主键约束或标识列属性)。 B、域完整性:限制类型(数据类型),格式(通过检查约束和规则),可能值范围(通过外键约束,检查约束,默认值定义,非空约束和规则)。 C、引用完整性:在删除和输入记录时,引用完整性保持表之间已定义的关系。引用完整性确保键值在所有表中一致,不能引用不存在的值.如果一个键。 D、自定义完整性:用户自己定义的业务规则,比如使用触发器实现自定义业务规则。

    02
    领券