当前位置:Gxlcms > 数据库问题 > [sql] 同库表(结构)的备份和sql聚合&navicat使用

[sql] 同库表(结构)的备份和sql聚合&navicat使用

时间:2021-07-01 10:21:17 帮助过:23人阅读

同库表的备份-赋值表结构和数据SQL语句

参考

有时候我们处理某个表时,需要先备份下这个表到当前这个库,然后再执行sql. 站在sql角度,就无需在mysqldump或者诸如导出sql的方式来备份了. 同库表的备份更简单

1.复制表结构及数据到新表

  1. <code>CREATE TABLE 新表 SELECT * FROM 旧表</code>

2.只复制表结构到新表

  1. <code>CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2
  2. 即:让WHERE条件不成立.
  3. 方法二:(由tianshibao提供)
  4. CREATE TABLE 新表 LIKE 旧表</code>

3.复制旧表的数据到新表(假设两个表结构一样)

  1. <code>INSERT INTO 新表 SELECT * FROM 旧表</code>

4.复制旧表的数据到新表(假设两个表结构不一样)

  1. <code>INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 旧表</code>

sql的autocommit

参考
执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

  1. <code>mysql> set autocommit=0;
  2. Query OK, 0 rows affected (0.01 sec)
  3. mysql> show variables like "autocommit";
  4. +---------------+-------+
  5. | Variable_name | Value |
  6. +---------------+-------+
  7. | autocommit | OFF |
  8. +---------------+-------+
  9. </code>

使用navicat需要特别注意两点

  • 有一点特别需要注意, 我发现如果navicat登录后首句执行的不是set autocommit = 0; 则会自动autocommit,即使你第二句设置了auto,对于这个会话也不生效了.
  • 第二点是autocommit是针对会话的.

技术分享图片

navicat快捷键

  1. <code>4.ctrl+r 运行查询窗口的sql语句
  2. 5.ctrl+shift+r 只运行选中的sql语句</code>

正确使用navicat的姿势

  1. <code>SET autocommit = 0;
  2. CREATE DATABASE maotai;
  3. DROP DATABASE maotai;
  4. ROLLBACK; #如果我后悔了即可
  5. COMMIT; #已确认sql没问题
  6. </code>

一般执行sql我都用navicat来搞,一方面便于核实结果复制给对方反馈,执行起来也顺手一些,因为写sql会有自动提示. ,在一方面他执行时候有快捷键

技术分享图片

mysql的事务

事务时怎么回事呢?

  1. <code>张三给李四转账500元。那么在数据库中应该是以下操作:
  2. 1,先查询张三的账户余额是否足够
  3. 2,张三的账户上减去500元
  4. 3,李四的账户上加上500元
  5. 以上三个步骤就可以放在一个事务中执行提交,要么全部执行要么全部不执行,如果一切都OK就commit提交永久性更改数据;如果出错则rollback回滚到更改前的状态。利用事务处理就不会出现张三的钱少了李四的账户却没有增加500元或者张三的钱没有减去李四的账户却加了500元。
  6. </code>

MyISAM与InnoDB引擎的区别

  1. <code>InnoDB支持事务,MyISAM不支持
  2. InnoDB支持外键,MyISAM不支持</code>

sql聚合函数

  1. <code>- 用sql语句做数据汇聚,查出status 和 对应的总数, 按照状态码总数来排序
  2. select status,sum(count) from log group by status;
  3. </code>

[sql] 同库表(结构)的备份和sql聚合&navicat使用

标签:...   net   永久   sql语句   一点   value   备份   tail   技术分享   

人气教程排行