mysql从入门到精通
解决MySQL Got a packet bigger than 'max_allowed_packet' bytes
问题在一次性向mysql插入的数据过大,可在my.ini中修改max_allowed_packet的配置项
修改my.ini如下:
max_allowed_packet=16M
重启mysql:
电脑->右键管理->服务->mysql重启
mysql排序按照中文文字的首字母进行排序
例如:下面使用字段common_producer_herb_info_name按照首字母a-z进行排序
SELECT * FROM e_common_producer_product_grade_info ORDER BY CONVERT(common_producer_herb_info_name USING gbk ) COLLATE gbk_chinese_ci ASC
mysql索引
/** * 根据基地和时间段获取原料出库列表 * @param $common_producer_info_id * @param int $wms_check_begin_at * @param int $wms_check_end_at * @return array */ public static function getWmsMaterialOutSumList($common_producer_info_id, $wms_check_begin_at=0, $wms_check_end_at=0){ $wms_check_end_at = !empty($wms_check_end_at) ? $wms_check_end_at : time(); //注意,一个出库单可以出库多个入库单的部分药材,即出库单不记录入库单号,只有出库详情才记录入库单号 //分组时不应该使用入库单号,而应该使用出库单号,因为一个入库单可以分多次出库 $sql = "SELECT modet.wms_stock_detail_info_relation_good_in_sheet_number in_sheet_number, mo.common_producer_info_id producer_id, mo.common_producer_info_name producer_name, mo.common_producer_herb_info_id info_id, mo.common_producer_herb_info_name info_name, mo.common_producer_herb_grade_info_id grade_id, mo.common_producer_herb_grade_name grade_name, SUM( IFNULL( modet.wms_material_out_sheet_detail_out_number, 0 ) ) AS sum_out_package_number, SUM( IFNULL( modet.wms_material_out_sheet_detail_out_weight, 0 ) ) AS sum_out_weight, SUM( IFNULL( modet.wms_material_out_sheet_detail_storage_loss_weight, 0 ) ) AS sum_out_loss_weight from {{%wms_material_out_sheet_detail}} modet LEFT JOIN {{%wms_material_out_sheet}} mo ON mo.id = modet.wms_material_out_sheet_id WHERE modet.is_del = 0 AND mo.is_del = 0 AND mo.wms_material_out_sheet_status = 1 AND mo.common_producer_info_id = :common_producer_info_id AND mo.wms_material_out_sheet_outgoing_date >= :wms_check_begin_at AND mo.wms_material_out_sheet_outgoing_date <= :wms_check_end_at GROUP BY mo.common_producer_herb_info_id, mo.common_producer_herb_grade_info_id, modet.wms_material_out_sheet_number, modet.wms_stock_detail_info_relation_good_in_sheet_number"; $list = Yii::$app->db->createCommand($sql) ->bindValue(':common_producer_info_id', $common_producer_info_id) ->bindValue(':wms_check_begin_at', $wms_check_begin_at) ->bindValue(':wms_check_end_at', $wms_check_end_at)->queryAll(); return $list; }
/** * 获取成品出库相关信息 * @param $common_producer_info_id * @param int $wms_check_begin_at * @param int $wms_check_end_at * @return array */ public static function getWmsProductOutSumList($common_producer_info_id, $wms_check_begin_at=0, $wms_check_end_at=0){ $wms_check_end_at = !empty($wms_check_end_at) ? $wms_check_end_at : time(); //注意:成品出库详情没有成品出库ID的关联字段,只能使用成品出库单号关联 //分组时不应该使用入库单号,而应该使用出库单号,因为一个入库单可以分多次出库 $sql = "SELECT po.wms_product_in_sheet_number in_sheet_number, po.common_producer_info_id producer_id, po.common_producer_info_name producer_name, po.common_producer_herb_info_id_product info_id, po.common_producer_herb_info_name_product info_name, po.common_producer_herb_grade_info_id_product grade_id, po.common_producer_herb_grade_name_product grade_name, SUM( IFNULL( podet.wms_product_out_detail_info_out_number, 0 ) ) AS sum_out_package_number, SUM( IFNULL( podet.wms_product_out_detail_info_out_weight, 0 ) ) AS sum_out_weight, SUM( IFNULL( podet.wms_product_out_detail_info_storage_loss_weight, 0 ) ) AS sum_out_loss_weight FROM {{%wms_product_out_detail_info}} podet LEFT JOIN {{%wms_product_out_sheet}} po ON po.wms_product_out_sheet_number = podet.wms_product_out_sheet_number WHERE podet.is_del = 0 AND po.is_del = 0 AND po.wms_product_out_sheet_status = 1 AND po.common_producer_info_id = :common_producer_info_id AND po.wms_product_out_sheet_product_out_date >= :wms_check_begin_at AND po.wms_product_out_sheet_product_out_date <= :wms_check_end_at GROUP BY po.common_producer_herb_info_id_product, po.common_producer_herb_grade_info_id_product, po.wms_product_out_sheet_number, podet.wms_product_in_sheet_number"; $list = Yii::$app->db->createCommand($sql) ->bindValue(':common_producer_info_id', $common_producer_info_id) ->bindValue(':wms_check_begin_at', $wms_check_begin_at) ->bindValue(':wms_check_end_at', $wms_check_end_at)->queryAll(); return $list; }
SELECT vms.info_name AS info_name, vms.grade_name AS grade_name, ( vms.sum_in_weight - vms.sum_out_weight ) AS weight, ( vms.sum_in_price - vms.sum_out_price ) AS price FROM ( SELECT pi.common_producer_herb_info_name_product info_name, pi.common_producer_herb_grade_name_product grade_name, SUM( IFNULL( pi.wms_product_in_sheet_in_weight, 0 ) ) AS sum_in_weight, SUM( IFNULL( pi.wms_product_in_sheet_unit_price, 0 ) ) AS sum_in_price, SUM( IFNULL( po.wms_product_out_sheet_out_weight, 0 ) ) AS sum_out_weight, SUM( IFNULL( po.wms_product_out_sheet_total_price, 0 ) ) AS sum_out_price FROM e_wms_product_in_sheet AS pi LEFT JOIN e_wms_product_out_sheet AS po ON pi.common_producer_herb_info_id_product = po.common_producer_herb_info_id_product AND pi.common_producer_herb_grade_info_id_product = po.common_producer_herb_grade_info_id_product AND po.is_del = 0 WHERE pi.is_del = 0 GROUP BY pi.common_producer_herb_info_id_product, pi.common_producer_herb_grade_info_id_product ) vms
mysql 常用函数
, wms_product_in_sheet_in_weight, ORDER BY id ASC;
第十 mysql导出数据库
在d:/mysql/bin中运行上述脚本,即可导出mysql形成sql文件,sql文件需要删除一行DTID。则能使用navicate导入sql文件到数据库
mysql从入门到精通的更多相关文章
- Mysql从入门到精通整理
目录 mysql基础 mysql进阶 mysql高级 mysql优化 正文 数据库是信息化产业的最基础的软件之一,各种管理系统,网站,在线游戏,背后基本都会有数据库的支持. 回到顶部 mysql基础 ...
- 《mysql从入门到精通》提高
第一 游标的使用 delimiter $$ DROP PROCEDURE IF EXISTS product_in_sheet_handler; CREATE PROCEDURE product_in ...
- MySQL数据库应用 从入门到精通 学习笔记
以下内容是学习<MySQL数据库应用 从入门到精通>过程中总结的一些内容提要,供以后自己复现使用. 一:数据库查看所有数据库: SHOW DATABASES创建数据库: CREATE DA ...
- 《MySQL数据库从入门到精通》 高级运维人才的必备书籍
众所周知,每年就业市场都会迎来千万量级的高校毕业生,然而企业招工难和毕业生就业难的矛盾却一直没有得到很好地解决.究其原因,主要矛盾还是在于传统的学历教育与企业实际需求相脱节.为了杜绝高校毕业生求职时常 ...
- 【MySQL】从入门到精通8-SQL数据库编程
上期:[MySQL]从入门到精通7-设计多对多数据库 第零章:Mac用户看这里: mac终端写MySQL和windows基本相同,除了配置环境变量和启动有些许不同以外. 先配置环境变量,在终端输入vi ...
- 【MySQL】从入门到精通9-数据库的备份(完结)
上期:[MySQL]从入门到精通8-SQL数据库编程 第一章:数据的导出 回到我们的Workbench. 选择Data Export. 选择需要导出的数据库. 注意,如果选择"Export ...
- 【MySQL】从入门到精通7-设计多对多数据库
上期:[MySQL]从入门到精通6-MySQL数据类型与官方文档 第一章:理解 和一对多不一样,多对多意思是,一个数据可以被不同的数据关联. 如果是一对多,我们还可以用外键来达成. 但是现在我们是多对 ...
- 【MySQL】从入门到精通6-MySQL数据类型与官方文档
上期:[MySQL]从入门到精通5-一对多-外键 这个是官方文档链接,是世界上最全面的MySQL教学了,所有问题都可以在这里找到解决方法. https://dev.mysql.com/doc/ htt ...
- Hibernate从入门到精通(三)Hibernate配置文件
在上次的博文Hibernate从入门到精通(二)Hibernate实例演示我们已经通过一个实例的演示对Hibernate的基本使用有了一个简单的认识,这里我们在此简单回顾一下Hibernate框架的使 ...
随机推荐
- pytorch visdom可视化工具学习—1—安装和使用
1.安装 安装命令: (deeplearning) userdeMBP:~ user$ pip install visdomCollecting visdom Downloading https:/ ...
- Emacs 中使用 shell
直接在 Emacs 中使用 shell 能增加一点效率.Emacs 本身支持的 shell 相关的命令很多,此处化繁为简,只用一条足够了. M-x shell:将打开一个名为 * shell * 的 ...
- 小技巧:改变 VS Code 工作区页面背景
效果图: 步骤(一): 1.点击页面左上角 文件/首选项/设置 2.在搜索框中输入:background 如下图. 3.找到 Background: Custom Images 选项并点击在 ...
- 在其他Activity中展示自定义相机拍的照片
在使用相机拍照中,我们需要当点击了确定按钮之后,拍的照片展示在其他Activity的ImageView中,代码如下: 1.首先在自定义相机的Activity中,处理点击拍照确定按钮后的逻辑功能:将图片 ...
- python之函数、参数、作用域、递归
函数的定义 函数也就是带名字的代码块.使用关键字def来定义,指出函数名及参数,以冒号结尾. def fibs(num): result =[0,1] for i in range(num-2): r ...
- Luogu P3321 [SDOI2015]序列统计
一道不错的多项式好题.还涉及了一些数论内容. 首先我们看到题目是求乘积模\(m\)的方案数,考虑到这种方案数我们一般都可以用生成函数来做. 但显然卷积的下标有加(FFT,NTT等)有位运算(FWT)但 ...
- 使用keras的LSTM进行预测----实战练习
代码 import numpy as np from keras.models import Sequential from keras.layers import Dense from keras. ...
- IDEA搭建本地服务器解决无法连接https://start.spring.io
通过IntellJ IDEA创建Spring Boot项目时,发生以下的问题.如图: 报错: 也许你搜到的都是诸如此类的回答: 在学习springboot的时候,使用IDEA的快速新建springbo ...
- SpringBoot整合定时任务异步任务
1.定时任务 1.开启定时任务 @SpringBootApplication //开启定时任务 @EnableScheduling public class SpringBootDemoApplica ...
- .NET开源项目 QuarkDoc 一款自带极简主义属性的文档管理系统
有些话说在前头 因为公司产品业务重构且功能拆分组件化,往后会有很多的接口文档需要留存,所以急需一款文档管理系统.当时选型要求3点: 1.不能是云平台上的Saas服务,整个系统都要在自己公司部署维护(数 ...