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相关推荐

  1. 转: mysql create view 创建视图

    以下的文章主要是对MySQL视图的描述,其中包括MySQ视图L概述,以及创建MySQL视图-create view与修改MySQL视图--alter view等相关内容的具体描述,以下就是文章的具体内 ...

  2. 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 ...

  3. mysql+create+table+index_mysql------基础及常见SQL技巧

    基础 1.1 mysql表复制 复制表结构+复制表数据 mysql>create table t3 like t1; mysql>insert into t3 select * from ...

  4. MySQL创建视图(CREATE VIEW)

    创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 基本语法 可以使用 CREATE VIEW 语句来创建视图. 语法格式如下: CREATE V ...

  5. 【数据库】MySQL创建视图(CREATE VIEW)

    数据库视图是什么? 创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 视图的好处? 视图使用的时候跟表一样.主要作用是不让所有的人都能看到整张表 ...

  6. 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 ...

  7. MySQL数据库——MySQL创建视图(CREATE VIEW)

    创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 基本语法 可以使用 CREATE VIEW 语句来创建视图. 语法格式如下: CREATE V ...

  8. 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 ...

  9. 2、创建视图(CREATE VIEW)

    创建视图是指在已经存在的 MySQL 数据库表上建立视图.视图可以建立在一张表中,也可以建立在多张表中. 基本语法 可以使用 CREATE VIEW 语句来创建视图. 语法格式如下: CREATE V ...

最新文章

  1. 从60多场技术面试中,我总结了这份面试经验
  2. HaoZip(好压) 去广告纯净版 4.4
  3. python PyQt5 QLCDNumber类(用于显示数字或一些符号的容器)
  4. python list转dict_python中将list转为dict
  5. 斐波那契数列不用数组_兔子数列——斐波那契数列
  6. qt获取场景的缩略图
  7. Linux程序设计之套接字: 循环服务 并发服务
  8. echarts环形图
  9. 《How to Write and Publish a Scientifc Paper》个人笔记
  10. Aberrant DSP SketchCassette II Mac(磁带混音效果插件)
  11. 管理新语:主管不要当传声筒,要检查、核实
  12. sidirect 连接西门子_INTOUCH DASSIDirect3.0 DASSIDirect3.0驱动是西门子PLC与Intouch连接通讯的必备驱动程序 - 下载 - 搜珍网...
  13. 【dp-背包】背包问题九讲
  14. python输入矩阵_python矩阵输入
  15. Pytorch实战宝可梦分类-自定义数据集完成宝可梦分类案例分步解析
  16. 世界读书日之后聊聊读书
  17. 遇见未来 | 对话叶毓睿:人类文明运行在软件之上(上篇)
  18. 《MATLAB编程》例题-画分段函数图像
  19. 马托石头问题-java(大马中马小马托石头)
  20. python使用结巴分词(jieba)创建自己的词典/词库

热门文章

  1. MySQL 5.6 dump/load buffer pool实验
  2. OenLayers 事件注册
  3. VM安装rhel或linux后,声音很响,如何关闭
  4. 数据结构上机实践第四周项目4 - 建设双链表算法库
  5. (二)元学习算法MAML简介及代码分析
  6. 【学习OpenCV4】什么是图像的直方图?如何获取直方图?
  7. RobotStudio机器人运行路径的创建与仿真
  8. python以读写方式打开文件_python 文件读写with open模式r,r+,w,w+,a,a+的区别
  9. delphi制作上下开幕效果_显示产业国际盛会开幕,广州新型显示产值将突破2500亿...
  10. 共享可写节包含重定位_周末去哪?来云浮!来乡村美食(番薯)节!