之前介绍了数据库的增删改查, 发现忘记了数据库的一些基本操作, 比如建库, 建表, 改表等等. 那这里就来小结一下数据库sql形式的基本操作.

一、库操作

1. 建库

在建库之前, 可能需要看一下, 数据库里面, 已经存在哪些库, 这样可以去处理重复的问题.

show databases;

这里之所以会出现newdb, 是因为我已经执行过下面的创建库的脚本了.

然后, 就可以创建库了.

create DATABASE newdb;

执行这句话, 就会按照默认编码的方式去创建数据库newdb. 那默认编码是什么呢, 来看一下:

show create database newdb;

如果想要在创建库的时候, 就指定好编码格式的话, 那么只需要按照上面这种模式去加就好了

create database newdb2 default character set utf8

其实编码不用管, 使用默认的方式就好.

2. 删库 -- 慎用

drop database newdb;

3. 引用库

如果你在1号库中, 想查询2号库的表, 那么就需要使用到这个

use test;

二、表操作

1. 建表

同样的, 建表之前, 要查询表中是否已存在我们想见的表.

show tables;

如果没有, 则可以开始新建表了, 如果库里面已经有了表模板, 并且你想在新建的时候, 导入部分数据, 那么应该使用下面这种方法:

create table tch_contact2 select * from tch_contact;

这样的话, tch_contact2能获取tch_contact的结构和数据, 但是并不能获取别的, 例如:索引, 外键, 触发器.

另外一种建表, 则稍微有点复杂

CREATE TABLE `contact` (
`Id` int(11) NOT NULL AUTO_INCREMENT, -- 不为空, 自动增长
`TId` int(11) DEFAULT NULL,
`QQ` varchar(15) DEFAULT NULL,
`Weixin` varchar(50) DEFAULT NULL,
`Phone` varchar(15) DEFAULT NULL,
PRIMARY KEY (`Id`), -- 设置主键
KEY `Index_TId` (`TId`) USING BTREE, -- 索引
CONSTRAINT `key_tid` FOREIGN KEY (`TId`) REFERENCES `tch_teacher` (`Id`) ON DELETE CASCADE ON UPDATE NO ACTION -- 设置外键
) COMMENT='就是这个表' -- 表注释

有时候需要用到临时表, 方法也很简单, 只需要在create table 中间加上一句 TEMPORARY 就可以了, 其他的, 都是和一般建表一样:

create temporary table '表名'()

1.1 设置主键

设置主键的语句, 可以分开写, 也可以合在一起写.

`Id` int(11) NOT NULL  PRIMARY key AUTO_INCREMENT,
-- 或者
`Id` int(11) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (`Id`),

1.2 设置索引 -- 索引这里有单个索引和复合索引, 但是设置方法都是一样的

mysql里面, 索引有三种类型, Normal, Unique, FullText. 索引方法由两种: Btree, Hash

-- 单个索引
KEY `Index_Weixin` (`Weixin`) USING BTREE,
UNIQUE KEY `Index_TId` (`TId`) USING HASH,
FULLTEXT KEY `Index_QQ` (`QQ`),
-- 复合索引
KEY `Index_fuhe` ('QQ', `Weixin`) USING BTREE,

我一般都只用Normal, Btree两个, 单个的和符合的都用.

1.3 外键

CONSTRAINT `key_tid` FOREIGN KEY (`TId`) REFERENCES `tch_teacher` (`Id`) ON DELETE CASCADE ON UPDATE NO ACTION

着句话, 看着可能有点费解, 但是看一下软件中的界面, 就非常清楚了

别的不需要解释了, 但是这里有个删除时, 更新时, 还是需要唠叨两句.

mysql这里, 有四个值可供选择.

RESTRICT -- 限制, 此限制是在更新之前.

在删除tch_teacher数据时, 如果tch_contact还有与之对应的值, 则删除失败

NO ACTION -- 限制, 此限制是在更新之后. 与Restrict触发的时间不同, 但是功能是一样的.

CASCADE -- 级联, 不限制删除, 但是会同步修改或删除.

如果tch_teacher删除一条数据, 那么tch_contact会同步删除, 与他关联的数据.

修改也是一样, 会同步修改.

SET NULL -- 设置为空, 如果tch_teacher删除一条数据, 那么tch_contact会将与之关联的那个字段设置为null, 不是把整条数据, 只是那个字段.

这里, 我觉得比较实用的就是 cascade了, 同步删除功能, 省下我不少工作呢.

2. 表操作

表操作又分为表结构修改和表名称修改. 先看表结构.

建好表之后, 发现其中的列, 并不完全是我想要的, 那咋搞呢?

2.1 查询列

show COLUMNS from tch_contact;

2.2  加列

alter table tch_contact add createby int comment '创建人';

2.3 修改列

alter table tch_contact MODIFY createby varchar(1);

alter table tch_contact change createby createby1 varchar(2);

2.4 减列

alter table tch_contact drop  createby;

2.5 索引

-- 新增一个索引
create index index_tid on tch_contact2(tid) using BTREE; alter table tch_contact2 add index index_weixin(weixin); -- 如果要修改一个索引, mysql里面, 只有先删除然后重建 -- 删除一个索引
drop index index_tid on tch_contact2;

2.6 外键

-- 新增一个外键
alter table tch_contact2 add CONSTRAINT
`key_tid` FOREIGN KEY (`TId`) REFERENCES `tch_teacher` (`Id`) ON DELETE CASCADE ON UPDATE NO ACTION; -- 删除一个外键
alter table tch_contact2 DROP FOREIGN KEY key_tid ;

2.7 表名称修改

rename table tch_contact to tch_contact1;

ALTER TABLE tch_contact1 RENAME tch_contact;
这两句都是表名称修改的语句.

3. 表删除 -- 慎用

drop table tch_contactt;

项目中最常用的, 其实也就是上面这些了.

Mysql - 数据库操作的更多相关文章

  1. php : mysql数据库操作类演示

    设计目标: 1,该类一实例化,就可以自动连接上mysql数据库: 2,该类可以单独去设定要使用的连接编码(set names XXX) 3,该类可以单独去设定要使用的数据库(use XXX): 4,可 ...

  2. php MySQL数据库操作类源代码

    php MySQL数据库操作类源代码: <?php class MySQL{ private $host; //服务器地址 private $name; //登录账号 private $pwd; ...

  3. 设计模式 - 单例模式mysql数据库操作类

    待续... index.php 调用方法: <?php header('Content-Type:text/html; charset=utf8'); require 'instance.php ...

  4. MySQL数据库操作常用命令

    MySQL数据库操作常用命令DOS连接数据库1.安装MySQL配置好环境2.运行cmd命令net start mysql3.找到mysql文件根目录输入命令mysql -h localhost -u ...

  5. Python/MySQL(四、MySQL数据库操作)

    Python/MySQL(四.MySQL数据库操作) 一.数据库条件语句: case when id>9 then ture else false 二.三元运算: if(isnull(xx)0, ...

  6. Java通过JDBC 进行MySQL数据库操作

    转自: http://blog.csdn.net/tobetheender/article/details/52772157 Java通过JDBC 进行MySQL数据库操作 原创 2016年10月10 ...

  7. Mysql 数据库操作之DDL、DML、DQL语句操作

    Mysql 数据库操作之DDL.DML.DQL语句操作 设置数据库用户名密码 l  Show databases 查看数据库列表信息 l  查看数据库中的数据表信息 ,格式: use 数据库名: sh ...

  8. Python进行MySQL数据库操作

    最近开始玩Python,慢慢开始喜欢上它了,以前都是用shell来实现一些自动化或者监控的操作,现在用Python来实现,感觉更棒,Python是一门很强大的面向对象语言,所以作为一个运维DBA或者运 ...

  9. Python3:sqlalchemy对mysql数据库操作,非sql语句

    Python3:sqlalchemy对mysql数据库操作,非sql语句 # python3 # author lizm # datetime 2018-02-01 10:00:00 # -*- co ...

  10. (转载)常用的Mysql数据库操作语句大全

    打开CMD,进入数据库命令:mysql -hlocalhost -uroot -p 退出数据库:exit 用户管理: 1.新建用户: >CREATE USER name IDENTIFIED B ...

随机推荐

  1. ASP.NET MVC 请求路径相关参数的获取

    Request.ApplicationPath / Request.CurrentExecutionFilePath /Home/Index Request.FilePath /Home/Index ...

  2. .NET 提升教育 第一期:VIP 付费课程培训通知!

    为响应 @当年在远方 同学的建议,在年前尝试进行一次付费的VIP培训. 培训的课件:点击下载培训周期:10个课程左右,每晚1个半小时培训价格:1000元/人.报名方式:有意向的请加QQ群:路过秋天.N ...

  3. 使用Visual Studio 2015 开发ASP.NET MVC 5 项目部署到Mono/Jexus

    最新的Mono 4.4已经支持运行asp.net mvc5项目,有的同学听了这句话就兴高采烈的拿起Visual Studio 2015创建了一个mvc 5的项目,然后部署到Mono上,浏览下发现一堆错 ...

  4. 【Reading Note】算法读书杂记

    1 排序 排序基本信息 稳定性:排序前大的数在排序后,大的数依然保持不变就是稳定排序,反之不稳定 内外排序:根据待排序的记录是否放在内存里面区分的.诸如:插入排序(直接插入&希尔).交换排序( ...

  5. Syscall,API,ABI

    系统调用(Syscall):Linux2.6之前是使用int0x80(中断)来实现系统调用的,在2.6之后的内核是使用sysentry/sysexit(32位机器)指令来实现的系统调用,这两条指令是C ...

  6. RMS:不能对生产服务器使用测试清单

    问题说明:在使用office软件RMS加密时报:不能对生产服务器使用测试清单,或者使用 rmsbulk.exe进行RMS加密时,报不能连接到RMS服务器. 解决办法: 请到https://suppor ...

  7. Android中Activity运行时屏幕方向与显示方式详解

    现在我们的手机一般都内置有方向感应器,手机屏幕会根据所处位置自动进行横竖屏切换(前提是未锁定屏幕方向).但有时我们的应用程序仅限在横屏或者竖屏状态下才可以运行,此时我们需要锁定该程序Activity运 ...

  8. MySQL 数据库双向同步复制

    MySQL 复制问题的最后一篇,关于双向同步复制架构设计的一些设计要点与制约. 问题和制约 数据库的双主双写并双向同步场景,主要考虑数据完整性.一致性和避免冲突.对于同一个库,同一张表,同一个记录中的 ...

  9. vim+vundle配置

    Linux环境下写代码虽然没有IDE,但通过给vim配置几个插件也足够好用.一般常用的插件主要包括几类,查找文件,查找符号的定义或者声明(函数,变量等)以及自动补全功能.一般流程都是下载需要的工具,然 ...

  10. js实现四大经典排序算法

    为了方便测试,这里写了一个创建长度为n的随机数组 function createArr(n) { var arr = []; while (n--) { arr.push(~~(Math.random ...