sql:Mysql create view,function,procedure
use test;create database Liber;use Liber;#顯示數据庫 20150210 Geovin Du 涂聚文
SHOW DATABASES;drop table BookKindList;
#书目录
create table BookKindList
(BookKindID INT NOT NULL AUTO_INCREMENT, #自动增加BookKindName nvarchar(500) not null,BookKindParent int null,PRIMARY KEY(BookKindID) #主键
);#这样也可以
create table BookKindList
(BookKindID INT NOT NULL PRIMARY KEY AUTO_INCREMENT, #自动增加#主键BookKindName nvarchar(500) not null,BookKindParent int null
);#书位置
create table BookPlaceList
(BookPlaceID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,BookPlaceName nvarchar(500) not null, BookPlaceParent int null);#书系列Series或套名称(一本的0.无,有分上下本)
drop table BookSeriesList;create table BookSeriesList
(BookSeriesID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,BookSeriesName nvarchar(500) not null
);
#職位Position
create table PositionList
(PositionID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,PositionName nvarchar(500) not null
);#部門Department ShortPY
create table DepartmentList
(DepartmentID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,DepartmentName nvarchar(500) not null
);insert into DepartmentList(DepartmentName) values ('行政部');
insert into DepartmentList(DepartmentName) values ('资讯部');select * from DepartmentList;#語种 Language
create table LanguageList
(LanguageID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,LanguageName nvarchar(500) not null
);#出版社Press #拼音索引
create table PressList
(PressID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,PressName nvarchar(500) not null);#作家Author
create table AuthorList
(AuthorID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,AuthorName nvarchar(500) not null
);#BookStatus 书藉存在状态(1,在用,2,报废,3。转移)
create table BookStatusList
(BookStatusID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,BookStatusName nvarchar(500) not null
);#借阅状态:借出,续借,归还,预借Lend, Renewal, Restitution,Reservations
create table LendStatusList
(LendStatusID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,LendStatusName nvarchar(500) not null
);#书信息
create table BookInfoList
(BookInfoID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,#自动增加#主键BookInfoKind int not null, #书籍类型外键BookInfoPlace int not null, #放置位置外键BookInfoISBN varchar(50) not null, #书籍ISBN编码BookInfoBarCode varchar(60) not null, #管理条码(barcode) BookInfoName nvarchar(500) not null, #书名BookInfoSeries int default 1, #书系列 ,0為無係列BookInfoAuthor int null, #作者BookInfoPress int null, #出版社BookInfoLanguage int null, #语种BookInfoPublish datetime , #出版时间BookInfoImage text null, #封面图片BookInfoStatus int default 1 not null, #书藉状态(1,在用(在库),2,报废,3。转移)BookInfoRemarks text null, #备注BookInfoOperatorId int null, #操作人员IDBookInfoAddDate datetime not null, #添加時間 可不以默认时间DEFAULT CURDATE()BookInfoPrice float default 1.00, #书价格BookUseCode varchar(100));desc BookKindList;#查询表结构show tables;#查询所有表select * from BookKindList; #查询insert into BookKindList(BookKindName,BookKindParent)values('六福书目录',0);insert into BookKindList(BookKindName,BookKindParent)values('文学',1);insert into BookKindList(BookKindName,BookKindParent)values('科学技术',1);/*自定义函数*/
#部门函数
DELIMITER $$
DROP FUNCTION IF EXISTS `geovindu`.`f_GetDepartmentName` $$
CREATE FUNCTION `geovindu`.`f_GetDepartmentName` (did int) RETURNS varchar(100)
BEGIN
declare str varchar(100);
return(select DepartmentName from DepartmentList where DepartmentID=did);
END $$
DELIMITER ;#使用函数
select f_GetDepartmentName(1);select * from BookInfoList;
#作家函数DELIMITER $$
DROP FUNCTION IF EXISTS `geovindu`.`f_GetAuthorName` $$
CREATE FUNCTION `geovindu`.`f_GetAuthorName` (did int) RETURNS varchar(400)
BEGINdeclare str varchar(100);
return(select AuthorName from AuthorList where AuthorID=did);
END $$
DELIMITER ;/*视图*/
select * from geovindu.views;desc View_BookInfoList;show create view View_BookInfoList;select * from View_BookInfoList;CREATE VIEW `geovindu`.`View_BookInfoList` ASselect BookInfoID , BookInfoKind , BookInfoPlace ,BookInfoSeries , BookInfoAuthor , BookInfoPress , BookInfoLanguage , BookInfoStatus , BookInfoOperatorId , BookInfoISBN , BookInfoBarCode , BookInfoName , BookInfoRemarks ,BookInfoAddDate,BookInfoPublish ,BookInfoPrice,
BookKindList.BookKindName,BookPlaceList.BookPlaceName,f_GetAuthorName(BookInfoAuthor)
from BookInfoList,BookKindList,BookPlaceList
where BookInfoList.BookInfoKind=BookKindList.BookKindID and BookInfoList.BookInfoPlace=BookPlaceList.BookPlaceID;/*储存过程 解决方案的思维模式基本相同,只是一些指令不同*/#IN 表示输入参数
#OUT表示输出参数
#INOUT:表示即可以输入参数也可以输出参数
#存储过程 利用mysql-query-browser创建存储过程和函数#删除
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`DeleteBookKind` $$
CREATE PROCEDURE `geovindu`.`DeleteBookKind` (IN param1 INT)
BEGINDelete From bookkindlist WHERE BookKindID = param1;
END $$
DELIMITER ;#查询所有
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`proc_Select_BookKindListAll()` $$
CREATE PROCEDURE `geovindu`.`proc_Select_BookKindListAll()` ()
BEGINSELECT * FROM bookkindlist;
END $$
DELIMITER ;select * from `geovindu`.`bookkindlist`;
SELECT * FROM bookkindlist;#统计
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`BookKindCount` $$
CREATE PROCEDURE `geovindu`.`BookKindCount` (OUT param1ID INT)
BEGINselect COUNT(*) into param1ID From bookkindlist;
END $$
DELIMITER ;#更新
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`proc_Update_BookKindList` $$
CREATE PROCEDURE `geovindu`.`proc_Update_BookKindList` (IN param1ID Int,IN param1Name NVarChar(1000),IN param1Parent Int)
BEGIN
IF NOT EXISTS (SELECT * FROM BookKindList WHERE BookKindName=param1Name) then #如果存在相同的记录,不更新名称
UPDATE BookKindListSETBookKindName=param1Name ,BookKindParent=param1ParentwhereBookKindID=param1ID;
ELSEUPDATE BookKindListSET BookKindParent=param1ParentwhereBookKindID=param1ID;
END IF;
END $$
DELIMITER ;#查询一条
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`proc_Select_BookKindList` $$
CREATE PROCEDURE `geovindu`.`proc_Select_BookKindList` (IN param1 INT)
BEGINSELECT * FROM BookKindList WHERE BookKindID = param1;
END $$
DELIMITER ;#插入一条
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`proc_Insert_BookKindList` $$
CREATE PROCEDURE `geovindu`.`proc_Insert_BookKindList` (IN param1Name NVarChar(1000),IN param1Parent Int)
BEGINinsert into BookKindList(BookKindName,BookKindParent) values(param1Name,param1Parent);
END $$
DELIMITER ;#插入一条返回值
DELIMITER $$
DROP PROCEDURE IF EXISTS `geovindu`.`proc_Insert_BookKindOut` $$
CREATE PROCEDURE `geovindu`.`proc_Insert_BookKindOut` (IN param1Name NVarChar(1000),IN param1Parent Int,OUT ID INT)
BEGINIF NOT EXISTS (SELECT * FROM BookKindList WHERE BookKindName=param1Name) then #如果存在相同的记录,不添加INSERT INTO BookKindList (BookKindName,BookKindParent)VALUES(param1Name ,param1Parent);#set ID=Last_insert_id()SELECT LAST_INSERT_ID() into ID;end if;
END $$
DELIMITER ;
sql:Mysql create view,function,procedure相关推荐
- 转: mysql create view 创建视图
以下的文章主要是对MySQL视图的描述,其中包括MySQ视图L概述,以及创建MySQL视图-create view与修改MySQL视图--alter view等相关内容的具体描述,以下就是文章的具体内 ...
- sql: table,view,function, procedure created MS_Description in sql server
--添加描述 Geovin Du --https://msdn.microsoft.com/en-us/library/ms180047.aspx --https://msdn.microsoft.c ...
- mysql+create+table+index_mysql------基础及常见SQL技巧
基础 1.1 mysql表复制 复制表结构+复制表数据 mysql>create table t3 like t1; mysql>insert into t3 select * from ...
- MySQL创建视图(CREATE VIEW)
创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 基本语法 可以使用 CREATE VIEW 语句来创建视图. 语法格式如下: CREATE V ...
- 【数据库】MySQL创建视图(CREATE VIEW)
数据库视图是什么? 创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 视图的好处? 视图使用的时候跟表一样.主要作用是不让所有的人都能看到整张表 ...
- CREATE VIEW SQL:通过SQL Server中的视图插入数据
This is the third article in a series of learning the CREATE VIEW SQL statement. So far, I'd say tha ...
- MySQL数据库——MySQL创建视图(CREATE VIEW)
创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 基本语法 可以使用 CREATE VIEW 语句来创建视图. 语法格式如下: CREATE V ...
- CREATE VIEW SQL:在SQL Server中使用索引视图
This is the fourth article in a series of learning the CREATE VIEW SQL statement. So far, we have do ...
- 2、创建视图(CREATE VIEW)
创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 基本语法 可以使用 CREATE VIEW 语句来创建视图. 语法格式如下: CREATE V ...
最新文章
- 从60多场技术面试中,我总结了这份面试经验
- HaoZip(好压) 去广告纯净版 4.4
- python PyQt5 QLCDNumber类(用于显示数字或一些符号的容器)
- python list转dict_python中将list转为dict
- 斐波那契数列不用数组_兔子数列——斐波那契数列
- qt获取场景的缩略图
- Linux程序设计之套接字: 循环服务 并发服务
- echarts环形图
- 《How to Write and Publish a Scientifc Paper》个人笔记
- Aberrant DSP SketchCassette II Mac(磁带混音效果插件)
- 管理新语:主管不要当传声筒,要检查、核实
- sidirect 连接西门子_INTOUCH DASSIDirect3.0 DASSIDirect3.0驱动是西门子PLC与Intouch连接通讯的必备驱动程序 - 下载 - 搜珍网...
- 【dp-背包】背包问题九讲
- python输入矩阵_python矩阵输入
- Pytorch实战宝可梦分类-自定义数据集完成宝可梦分类案例分步解析
- 世界读书日之后聊聊读书
- 遇见未来 | 对话叶毓睿:人类文明运行在软件之上(上篇)
- 《MATLAB编程》例题-画分段函数图像
- 马托石头问题-java(大马中马小马托石头)
- python使用结巴分词(jieba)创建自己的词典/词库
热门文章
- MySQL 5.6 dump/load buffer pool实验
- OenLayers 事件注册
- VM安装rhel或linux后,声音很响,如何关闭
- 数据结构上机实践第四周项目4 - 建设双链表算法库
- (二)元学习算法MAML简介及代码分析
- 【学习OpenCV4】什么是图像的直方图?如何获取直方图?
- RobotStudio机器人运行路径的创建与仿真
- python以读写方式打开文件_python 文件读写with open模式r,r+,w,w+,a,a+的区别
- delphi制作上下开幕效果_显示产业国际盛会开幕,广州新型显示产值将突破2500亿...
- 共享可写节包含重定位_周末去哪?来云浮!来乡村美食(番薯)节!