代码收藏系列--mysql--创建数据库、数据表、函数、存储过程命令
创建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--创建数据库、数据表、函数、存储过程命令的更多相关文章
- PHP创建数据库数据表
PHP创建数据库数据表 <?php $con = mysql_connect('localhost', 'root', 'root'); /************************在数据 ...
- MySQL处理数据库和表的常用命令
MySQL处理数据库和表的常用命令 [导读] 学习如何管理和导航MySQL数据库和表是要掌握的首要任务之一,下面的内容将主要对MySQL的数据库和表的一些常用命令进行总结,一些我们不得不掌握的命令,一 ...
- MYSQL 创建数据库以及表
创建数据库,表 创建一个数据库,再在数据库下创建一个或多个表,不难,记不住的同学可以直接copy,慢慢的用会即刻,懂的同学请看代码,没有太多基础的同学,除了看代码,请看最下方的知识点 创建数据库: C ...
- 数据库之mysql篇(3)—— mysql创建/修改数据表/操作表数据
创建数据表:create table 数据表名 1.创建表规范 create table 表名( 列名 数据类型 是否为空 自动排序/默认值 主键/外键/唯一键, 列名 数据类型 ...
- MySQL创建数据库和表的Demo
Demo: 创建数据库的语法 1.基本语法 create database tour character set gbk; use tour; 无主键自增长的 create table EMB_T_E ...
- PHP MySQL 创建数据库和表 之 Create
创建数据库 CREATE DATABASE 语句用于在 MySQL 中创建数据库. 语法 CREATE DATABASE database_name 为了让 PHP 执行上面的语句,我们必须使用 my ...
- MySQL操作数据库和表的常用命令新手教程
1.查看数据库 获取服务器上的数据库列表通常很有用.执行show databases;命令就可以搞定. mysql> show databases; 2.创建数据库 mysql> crea ...
- SQL创建数据库、表、存储过程及调用
--如果存在数据库PRogrammerPay 就删除 if exists (select * from sysdatabases where name='programmerPay') drop d ...
- mysql创建数据库、表、写数据
mysql> create database ceshi; Query OK, 1 row affected (0.01 sec) 给数据库授权,否则程序时无法连接ceshi数据库的,每次创建一 ...
随机推荐
- 180718-jar包执行传参使用小结
jar包执行时传参的使用姿势 虽说我们现在大多不太直接使用jar包运行方式,目前比较主流的是将自己的服务丢在某个容器中(如tomcat,jetty等)运行,比如我之前所属的电商公司,就是将项目打包为w ...
- 发送请求工具—Advanced REST Client的安装使用
1. 0 下载得到Advanced-REST-client_v3.1.9.zip 链接:http://pan.baidu.com/s/1c0vUnJi 密码:z34d 1.1 解压Advanced-R ...
- 1.6 JAVA高并发之线程池
一.JAVA高级并发 1.5JDK之后引入高级并发特性,大多数的特性在java.util.concurrent 包中,是专门用于多线程发编程的,充分利用了现代多处理器和多核心系统的功能以编写大规模并发 ...
- 随机生成30道四则运算-NEW
补充:紧跟上一个随机生成30道四则运算的题目,做了一点补充,可以有真分数之间的运算,于是需要在原来的基础上做一些改进. 首先指出上一个程序中的几个不足:1.每次执行的结果都一样,所以不能每天给孩子出3 ...
- 基础系列(1)—— NET框架及C#语言
一.在.NET之前的编程世界 C#语言是在微软公司的.NET框架上开发程序而设计的,首先作者给大家纠正了一下C#的正确发音:See Sharp (一) 20世纪90年代末的Windows编程 这时大多 ...
- web表格代码(5)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- QUdpSocket-Qt使用Udp通讯实现服务端和客户端
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QUdpSocket-Qt使用Udp通讯实现服务端和客户端 本文地址:https:// ...
- webpack打包多html开发案例新
闲来无事在原来简单打包案例的基础上,参考vue-cli的打包代码,改为多文件打包. 区别于上篇文章<webpack打包多html开发案例>,此次打包根据开发的不同环节进行打包,也就是有开发 ...
- PHP中普通属性和静态属性
普通属性(实例属性): 实例的单词为:instance 实例,其实也叫做“对象”: 普通(实例)属性,就是一个可以在该类实例化出的对象上使用的属性! 定义形式: class 类名{ var $属性 ...
- Java知识点整理(一)
ArrayList和LinkedList的区别 1.ArrayList和LinkedList可想从名字分析,它们一个是Array(动态数组)的数据结构,一个是Link(链表)的数据结构,此外,它们两个 ...