MySQL 插入数据并检查重复
作者:V君 发布于:2016-7-27 14:15 Wednesday 分类:挖坑经验
TL;DR: 基于爆栈回答修改
INSERT INTO `bsc_data` (`Name`)
SELECT 'bala' FROM `bsc_data`
WHERE NOT EXISTS (SELECT 1 FROM `bsc_data` WHERE `Name` = 'bala') LIMIT 1 ;
蛋点总结:
MySQL 单纯执行语句不能像 SQL Server 那样用 IF 流控制语句, 只能WHERE来变通
并且还要小心炸库, 因为写少了 LIMIT 1, 导致第一行 SELECT 条件为成立
产生与表行数相等的重复数据
还奇怪为啥几十行数据插入这么久, 原来数据库爆炸了, 还删好久才删干净...
偷偷更新:
用惯了MySQL之后真回不去M$SQL,当你需要检查id是否存在重复,否则插入数据的时候.
只需要加一个IGNORE在INSERT关键字后面就可以轻松解决
应避免的 LINQ to SQL 聚合投影空值错误
作者:V君 发布于:2016-7-15 11:06 Friday 分类:挖坑经验
根本原因: SQL 在进行 SUM 这类聚合查询时如果一条数据也没有, 会得到 NULL.
如果你的投影结果字段用了不可空类型, 将会引发错误: null 无法赋值到不可空类型.
解决方法: 将聚合投影字段转换成可空, 并将聚合结果做空处理, 一般把空转成0.
可能出错的写法:
var result = DataBase.Table.Sum(p=>p.Amount);
修改以避免错误:
var result = DataBase.Table.Sum(p=>(decimal?)p.Amount)) ?? 0;
ASP.NET Boilerplate 提示友好错误信息
作者:V君 发布于:2016-6-15 12:17 Wednesday 分类:挖坑经验
TL;DR:
启用错误页面模式在 web.config 就可以得到带错误信息友好提示页面
若返回 Json 则把 ActionResult 改为 JsonResult
需要注意的是, 用来代替的错误信息页面 error.cshtml 不能再次引发异常
否则仍然会显示默认的无堆栈黄页
ABP内置的UserFriendlyException很好用, 但是不正确配置的话还是会给你黄页.
尽管官网文档描述得很详细, 但是TL;DR版本还是可以有的!
重新认识EntityFramework, 比较几个LINQ数据访问/ORM库
作者:V君 发布于:2016-5-27 9:29 Friday 分类:挖坑经验
前些年我曾说过 Entity Framework 就是个坑
但自从最近试着摆弄 ASP.NET Boilerplate Project 对Entity Framework大有改观.
原来版本6之后的Entity Framework完全可以把dbml dbLinq linq2db sqlite-net远远甩在后头.
dbml - LINQ to SQL 类
◆能从数据库生成设计器代码, 也能先设计再生成数据库
◆完整的复杂查询/投影支持
◇仅限MsSQL
dbLinq - 上者的一个类似克隆一样的实现 GitHub
◆支持多种数据库
○能从数据库生成设计器代码, 不支持自动创建数据库
◇复杂查询/投影不完善
linq2db - 近些年发起的开源LINQ数据访问/ORM库, 看起来是上者的重新实现 GitHub
◆支持多种数据库
◆完整的复杂查询/投影支持
◆能从实体类生成数据库, 也能从数据库生成实体类(T4)
sqlite-net - 轻量级sqlite数据访问实现, 因为轻量所以没太多功能 GitHub
◆单个源码文件加到项目即可使用
◆跨平台直接调用原生实现, 不依赖ADO.NET
○简单的LINQ支持
◇不支持复杂查询/投影
Entity Framework 6+ - 着看怎么完爆上面这堆
◆上述除了轻量级之外的所有优点
◆多种开始方式: CodeFirst,DbFirst,ModelFirst. (不过 CodeFist 就够了)
◆支持迁移,能按你对模型类的变更生成数据库更新脚本
◇目前尚未发现有缺点
◇使用一段时间后总算是找到了些缺点(?),可能是考虑到兼容不同数据库
LINQ表达式解析依赖于提供程序实现,
比如MySQL提供程序实现的表达式解析器的解析和投影就BUG满满,
具体表现为各种操作符报不支持或者导航属性投影字段混淆.
总之赶紧来用这货吧 ゚∀゚)σ
偷偷更新:其实EF的迁移并不太好使,还是基于现有数据库的CodeFirst跟Dapper混搭好 乂目
使用SOCKET需谨慎,莫让TCP Keep-Alive把你流量耗光
作者:V君 发布于:2016-1-25 18:13 Monday 分类:挖坑经验
今天收到报告
说终端设备跑流量超标很厉害
因为不是咱的代码(将来就是了吧)
问了些情况 --
应用层面日志很正常
原始数据也不多
(虽然仅记录从设备发来的)
怀疑是不是服务器抽风
一个劲的下发数据
于是直接上去抓包了
抓了一个小时, 打包传回
\\我一看→→→→→// (葛炮音
哎哟我的玛雅 按这个间隔
一个月能跑掉30M流量
对SOCKET/TCP/IP了解不多 不知道这是不是正常现象 不过从流量上来看绝对不正常
咕狗 && 问万能的麻衣阿姨 再回来看代码 ↓↓↓↓↓↓↓↓↓↓↓
嗯嗯 这下啪啪打脸, 走GSM无线的你拿来拔网线 (´∀((☆ミつ
这下应该好了吧 (竖起拇指+牙齿闪光
次日更:
不要觉得这样就大丈夫了, 还有问题 -- 连接数用完
又抓了一个小时, 发现大概每隔50秒会重新连接
看来还是要开Keep-Alive, 设置到40秒吧, 每个月需要消耗2~3M流量
继续观察...最后决定设置为45秒, 之后终于不浪费流量了.
blogger
Google Web Translator
热门日志
随机日志
最新日志
最新评论
- V君
@Quartz:(出现)... - Quartz
怎么不见人了呢... - V君
@Soar:DHCP 协议相... - V君
@Soar:当然是非... - Soar
@V君:谢谢 有空... - Soar
搞一个 1230v3+B85... - V君
@Soar:另外,也可... - V君
@Soar:iscsi服务端... - Soar
难怪这么卡,尤其... - Soar
clone了源码,提示...
分类
存档
- 2024年5月(1)
- 2023年7月(1)
- 2023年5月(1)
- 2022年11月(1)
- 2022年10月(1)
- 2022年9月(1)
- 2022年8月(1)
- 2022年7月(1)
- 2022年6月(1)
- 2022年5月(2)
- 2022年4月(1)
- 2022年3月(1)
- 2022年2月(1)
- 2022年1月(1)
- 2021年12月(1)
- 2021年11月(1)
- 2021年10月(1)
- 2021年9月(1)
- 2021年8月(1)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(1)
- 2021年4月(1)
- 2021年3月(1)
- 2021年2月(1)
- 2021年1月(1)
- 2020年12月(1)
- 2020年11月(1)
- 2020年10月(2)
- 2020年9月(1)
- 2020年8月(1)
- 2020年7月(1)
- 2020年6月(1)
- 2020年5月(1)
- 2020年4月(2)
- 2020年3月(3)
- 2020年2月(1)
- 2020年1月(1)
- 2019年12月(1)
- 2019年11月(1)
- 2019年10月(1)
- 2019年9月(1)
- 2019年8月(2)
- 2019年7月(1)
- 2019年6月(1)
- 2019年5月(1)
- 2019年4月(1)
- 2019年3月(1)
- 2019年2月(1)
- 2019年1月(2)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(3)
- 2018年9月(4)
- 2018年8月(6)
- 2018年7月(4)
- 2018年6月(1)
- 2018年5月(2)
- 2018年4月(2)
- 2018年3月(3)
- 2018年2月(1)
- 2018年1月(1)
- 2017年12月(1)
- 2017年10月(2)
- 2017年9月(1)
- 2017年8月(2)
- 2017年7月(1)
- 2017年6月(5)
- 2017年5月(2)
- 2017年4月(2)
- 2017年3月(3)
- 2017年2月(2)
- 2017年1月(2)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(3)
- 2016年9月(4)
- 2016年8月(2)
- 2016年7月(4)
- 2016年6月(3)
- 2016年5月(1)
- 2016年4月(4)
- 2016年3月(3)
- 2016年2月(1)
- 2016年1月(5)
- 2015年12月(4)
- 2015年11月(5)
- 2015年10月(1)
- 2015年9月(6)
- 2015年8月(4)
- 2015年7月(1)
- 2015年6月(6)
- 2015年5月(3)
- 2015年4月(3)
- 2015年3月(2)
- 2015年2月(1)
- 2015年1月(3)
- 2014年12月(1)
- 2014年11月(1)
- 2014年10月(1)
- 2014年9月(3)
- 2014年8月(1)
- 2014年7月(1)
- 2014年6月(1)
- 2014年5月(3)
- 2014年4月(1)
- 2014年3月(1)
- 2014年2月(2)
- 2014年1月(1)
- 2013年12月(2)
- 2013年11月(2)
- 2013年10月(1)
- 2013年9月(3)
- 2013年8月(14)
- 2013年7月(7)
- 2013年4月(1)
- 2013年3月(4)
- 2013年2月(6)
- 2013年1月(6)
- 2012年12月(8)
- 2012年11月(6)