创建mysql数据库

CREATE DATABASE IF NOT EXISTS `database_name` DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

创建mysql数据表

drop table if exists `table_name`;
create table if not exists `table_name` (
id int auto_increment primary key comment '主键编号',
`name` varchar(32) not null default '' comment '名称',
`code` varchar(32) not null default '' comment '代码',
category_id int not null default 0 comment '类别编号',
create_time timestamp not null default CURRENT_TIMESTAMP comment '创建时间(年月日)',
INDEX idx_name (`name`), -- 普通索引
INDEX idx_name_category_id (`code`,category_id), -- 复合索引
UNIQUE INDEX idxu_code (`code`) -- 唯一索引
-- 注意,最后一行不能有逗号
) ENGINE=InnoDB DEFAULT CHARSET=utf8 comment '创建表\r\n2017-06-21';

补充说明:
1. MySQL数据库的varchar(M),M表示的是字符数量,而不是字节数量,占用的字节数和数据表使用的编码有关。(一个中文、英文、数字等都算一个字符)
2. MySQL要求一个行的定义长度不能超过65535字节,因此varchar的长度理论上最大是65535字节,编码若为gbk,每个字符最多占2个字节,最大长度不能超过32766个字符;编码若为utf8,每个字符最多占3个字节,最大长度不能超过21845个字符,即不论字母、数字或汉字,只能存储21785个
3. create_timestamp int not null default UNIX_TIMESTAMP() comment '创建时间(UNIX时间戳格式)' 这种语法不能通过,因为mysql默认值只能支持常量,变量是不被允许的,所有可以使用其他的方式,或者程序每次都插入时间戳来实现

文章参考:http://www.cnblogs.com/sochishun/p/7026762.html

例如:
1个中文用UTF8编码是3字节(Byte),用GBK编码是2字节(Byte)。1个英文或数字不管什么编码都是1字节(属于ASCII编码)。
'中文' 2个汉字的长度是 3byte * 2 = 6byte
'E文' 1个英文+1个汉字的长度是 1byte + 3byte = 4byte
'a0' 1个英文+1个数字的长度是 1byte + 1byte = 2byte
GBK的文字编码用双字节来表示,即不论中、英文字符均使用双字节来表示
'中文' 2个汉字的长度是 2byte * 2 = 4byte
'E文' 1个英文+1个汉字的长度是 1byte + 2byte = 3byte
'a0' 1个英文+1个数字的长度是 1byte + 1byte = 2byte

创建mysql视图

create or replace view `view_name` as select * from `table_name`;

创建mysql存储过程

/**
* mysql游标
* @since 1.0 2015-3-28 sochishun Added.
*/
DELIMITER ;;
drop procedure if exists proc_cursor_demo;;
create procedure proc_cursor_demo()
begin
declare vint_id int;
declare vstr_name varchar(32);
declare done boolean default false;
-- 计费游标
declare cur1 cursor for select `id`, `name` from `table_name` where id < 100;
-- 将结束标志绑定到游标
declare continue handler for not found set done = true; open cur1;
loop_label: loop
fetch cur1 into vint_id, vstr_name; -- 声明结束的时候
if done then
leave loop_label;
end if;
call proc_update_demo(vint_id, vstr_name);
end loop;
close cur1;
end;;
DELIMITER ;

创建mysql函数

/**
* 创建mysql函数
* @since 1.0 2016-2-18 by sochishun
* @example SIP/301-00000155
*/
DELIMITER ;;
drop function if exists fn_test_demo;;
create function fn_test_demo(pstr_channel varchar(32))
returns varchar(16) -- 函数返回定义写在这里
begin
declare vstr_prefix varchar(16);
declare vstr_out varchar(16);
set vstr_prefix=LEFT(pstr_channel,3);
if vstr_prefix='SIP' then
set vstr_out=SUBSTR(pstr_channel,5,POSITION('-' IN pstr_channel)-5);
elseif vstr_prefix='Loc' then
set vstr_out=SUBSTR(pstr_channel,7,POSITION('@' IN pstr_channel)-7);
else
set vstr_out=pstr_channel;
end if;
return vstr_out;
end;;
DELIMITER ;

查看系统信息命令

-- 查询所有数据库
select SCHEMA_NAME,DEFAULT_CHARACTER_SET_NAME,DEFAULT_COLLATION_NAME from information_schema.schemata where SCHEMA_NAME not in ('mysql','information_schema','performance_schema'); -- 查询数据库中所有表
select TABLE_NAME, TABLE_TYPE, ENGINE, DATA_LENGTH, CREATE_TIME, TABLE_COLLATION, TABLE_COMMENT from information_schema.tables where TABLE_SCHEMA='db_test_v1' AND TABLE_TYPE='BASE TABLE'; -- 查询存储过程和函数
select ROUTINE_NAME from information_schema.routines WHERE ROUTINE_SCHEMA='db_test_v1' AND ROUTINE_TYPE='FUNCTION';
select ROUTINE_NAME from information_schema.routines WHERE ROUTINE_SCHEMA='db_test_v1' AND ROUTINE_TYPE='PROCEDURE'; -- 查询所有视图
select TABLE_NAME from information_schema.views where TABLE_SCHEMA='db_test_v1';
select TABLE_NAME from information_schema.tables where TABLE_SCHEMA='db_test_v1' AND TABLE_TYPE='VIEW'; -- 查询所有字段
select COLUMN_NAME, IS_NULLABLE, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, NUMERIC_PRECISION, NUMERIC_SCALE, EXTRA, COLUMN_COMMENT from information_schema.columns WHERE TABLE_SCHEMA='db_test_v1' AND TABLE_NAME='t_test'; -- 查询索引和主键
select * from information_schema.table_constraints where TABLE_SCHEMA='db_test_v1' AND TABLE_NAME='t_test'; -- 查询数据库全局变量
select VARIABLE_NAME, VARIABLE_VALUE FROM information_schema.global_variables;

版权声明:本文采用署名-非商业性使用-相同方式共享(CC BY-NC-SA 3.0 CN)国际许可协议进行许可,转载请注明作者及出处。
本文标题:代码收藏系列--mysql--创建数据库、数据表、函数、存储过程命令
本文链接:http://www.cnblogs.com/sochishun/p/7061693.html
本文作者:SoChishun (邮箱:14507247#qq.com | 博客:http://www.cnblogs.com/sochishun/)
发表日期:2017年6月23日

代码收藏系列--mysql--创建数据库、数据表、函数、存储过程命令的更多相关文章

  1. PHP创建数据库数据表

    PHP创建数据库数据表 <?php $con = mysql_connect('localhost', 'root', 'root'); /************************在数据 ...

  2. MySQL处理数据库和表的常用命令

    MySQL处理数据库和表的常用命令 [导读] 学习如何管理和导航MySQL数据库和表是要掌握的首要任务之一,下面的内容将主要对MySQL的数据库和表的一些常用命令进行总结,一些我们不得不掌握的命令,一 ...

  3. MYSQL 创建数据库以及表

    创建数据库,表 创建一个数据库,再在数据库下创建一个或多个表,不难,记不住的同学可以直接copy,慢慢的用会即刻,懂的同学请看代码,没有太多基础的同学,除了看代码,请看最下方的知识点 创建数据库: C ...

  4. 数据库之mysql篇(3)—— mysql创建/修改数据表/操作表数据

    创建数据表:create table 数据表名 1.创建表规范 create table 表名( 列名   数据类型    是否为空   自动排序/默认值  主键/外键/唯一键, 列名   数据类型 ...

  5. MySQL创建数据库和表的Demo

    Demo: 创建数据库的语法 1.基本语法 create database tour character set gbk; use tour; 无主键自增长的 create table EMB_T_E ...

  6. PHP MySQL 创建数据库和表 之 Create

    创建数据库 CREATE DATABASE 语句用于在 MySQL 中创建数据库. 语法 CREATE DATABASE database_name 为了让 PHP 执行上面的语句,我们必须使用 my ...

  7. MySQL操作数据库和表的常用命令新手教程

    1.查看数据库 获取服务器上的数据库列表通常很有用.执行show databases;命令就可以搞定. mysql> show databases; 2.创建数据库 mysql> crea ...

  8. SQL创建数据库、表、存储过程及调用

    --如果存在数据库PRogrammerPay  就删除 if exists (select * from sysdatabases where name='programmerPay') drop d ...

  9. mysql创建数据库、表、写数据

    mysql> create database ceshi; Query OK, 1 row affected (0.01 sec) 给数据库授权,否则程序时无法连接ceshi数据库的,每次创建一 ...

随机推荐

  1. ideal快捷键

    百度一搜索,发现很多快捷键说明,我但是有些说得不对的,我列出来的这些快捷键,有一部分是需要你百度好久,甚至百度一上午才能搜索出来的,并且戴着老花镜.这样的话,在实际工作者,对于初级程序员来说,成本太高 ...

  2. JavaScript学习笔记(五)——类型、转换、相等、字符串

    第六章 类型 相等 转换等 一.类型 1 typeof(); typeof是一个内置的JavaScript运算符,可用于探测其操作数的类型. 例: <script language=" ...

  3. 使用HackRF和外部时钟实现GPS欺骗实验

    本文内容.开发板及配件仅限用于学校或科研院所开展科研实验! 淘宝店铺名称:开源SDR实验室 HackRF链接:https://item.taobao.com/item.htm?spm=a1z10.1- ...

  4. JAVA学习笔记--数组初始化

    JAVA中,数组只是相同类型的.用一个标识符名称封装到一起的一个对象序列或基本类型数据序列.数组通过方括号下标操作符[]来定义和使用,要定义一个数组只需在类型名后面加上一个方括号即可,如: int[] ...

  5. eos开发实践

    一 下载前端代码 git clone https://github.com/baidang201/eos-todo 二 安装nodejs sudo apt-get install python-sof ...

  6. ntp时钟服务器配置

    集群中时间不同步有可能会让大数据的应用程序运行混乱,造成不可预知的问题,比如Hbase,当时间差别过大时就会挂掉,所以在大数据集群中,ntp服务,应该作为一种基础的服务,以下在演示在CentOS 7. ...

  7. 2014-2015 ACM-ICPC, NEERC, Eastern Subregional Contest Problem H. Pair: normal and paranormal

    题目链接:http://codeforces.com/group/aUVPeyEnI2/contest/229669 时间限制:1s 空间限制:64MB 题目大意:给定一个长度为2n,由n个大写字母和 ...

  8. HDU 1257 最少拦截系统(最长递减子序列的条数)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1257 题解: #include<iostream> #include<cstdio ...

  9. HDU 5170 GTY's math problem 水题

    题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5170 bc(中文):http://bestcoder.hdu.edu.cn/contests ...

  10. DB2 UDB V8.1 管理

    在DB2中有关实例(Instance), 数据库(Database),表空间(TableSpace),容器(Container)等概念: 在一个操作系统中,DB2数据服务可以同时运行多个实例(有别于O ...