Written by 正冰 on 2020, March 21, 2:06 PM
有个mysql数据库名为db1,里面有个table1表,表中有几千万条数据,目前有个需求,需要把这个表中2020年3月21日的数据导出到sql文件,下载到本地并导入本地数据库中。
命令如下:mysqldump -uroot -p db1 table1 --where="date like '2020-03-21%'" > table1.sql
解释:使用数据库的root用户导出db1数据库中table1标中符合条件的数据(date是2020年3月21日)到当前目录下的tables1.sql文件。
Filed under: 技术归总
0 Comments
1600 Views
Written by 正冰 on 2020, March 21, 1:16 PM
今天在操作某个MySQL数据库(InnoDB引擎)的test表的时候,出现了问题,导致该表无法访问,访问的时候就提示错误:ERROR 1033 (HY000): Incorrect information in file: './test/test.frm'
按照错误信息提示信息的意思就是这个frm后缀的文件存在错误信息,那么这个文件是干什么的呢?为什么访问数据表会提示这个信息?怎么修复?
frm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果出现特殊情况出现frm文件损坏也不要放弃希望,当修复MyISAM和InnoDB表时,MySQL服务会首先去调用frm文件,所以我们只能通过修复frm文件进行后面的数据恢复。
也就是说frm是表结构文件,通过mysql数据库自带的修复命令无法修复成功,只能另辟蹊径。
方法:找到该数据表的备份sql文件,另外建立一个数据库test2,将备份文件导入该数据库中,然后在命令行下先将原来的test数据库中的test.frm重命名一下,再将test2数据库的test.frm文件复制test数据库目录下。再次访问test表,没有问题了。
Filed under: 技术归总
0 Comments
1849 Views
Written by 正冰 on 2020, February 27, 10:08 PM
本文更新于2020年2月27日
0、下载树莓派专用的CentOS系统
- http://mirrors.huaweicloud.com/centos-altarch/7.7.1908/isos/armhfp/CentOS-Userland-7-armv7hl-RaspberryPI-Minimal-1908-sda.raw.xz
1、安装xz解压命令
- 访问https://tukaani.org/xz/下载最新压缩包,最新的是xz-5.2.4.tar.gz
2、解压缩并安装
- tar zxvf xz-5.2.4.tar.gz
- ./configure
- make && make install
3、验证安装结果并解压缩CentOS树莓派版压缩包
- xz -V
- xz -d CentOS-Userland-7-armv7hl-RaspberryPI-Minimal-1908-sda.raw.xz
4、插入TF卡后使用df -h查看磁盘名称并卸载
- df -h
- diskutil unmount /dev/disk3s1
- sudo dd bs=4m if=CentOS-Userland-7-armv7hl-RaspberryPI-Minimal-1908-sda.raw of=/dev/rdisk3
- diskutil unmount /dev/disk3s1
5、把TF卡插到树莓派中,连接路由器并通电,登录路由器后台获取树莓派IP
6、远程登录,root密码centos,将时区改为上海时区并同步最新时间
- timedatectl set-timezone Asia/Shanghai
- yum -y install ntp
- ntpdate ntp1.aliyun.com
7、默认分区不合理,需要把所有空间都划到根目录
- 查看分区挂载情况 lsblk
- NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
- mmcblk0 179:0 0 14.9G 0 disk
- ├─mmcblk0p2 179:2 0 488M 0 part [SWAP]
- ├─mmcblk0p3 179:3 0 1.4G 0 part /
- └─mmcblk0p1 179:1 0 286M 0 part /boot
8、查看到/根目录的挂载的位置是/dev/mmcblk0p3,只需要怼它进行调整
- fdisk /dev/mmcblk0 #执行扩展分区操作
- p #查看旧分区情况,记录p3位置起始为1593344
- d #删除分区,默认是3号分区
- n #添加一个分区,空间起始位置(First sector)输入1593344,然后一路回车完成
- p #查看新分区情况
- w #写入分区信息并退出软件
9、重启系统,开机后执行命令重新加载分区信息
- reboot
- resize2fs /dev/mmcblk0p3
- df -h
10、安装个LNMP玩玩(宝塔不支持32位系统)
- yum -y install wget && wget http://soft.vpser.net/lnmp/lnmp1.6.tar.gz -cO lnmp1.6.tar.gz && tar zxf lnmp1.6.tar.gz && cd lnmp1.6 && ./install.sh lnmp
11、花了2小时完成安装
- Install lnmp takes 129 minutes.
- Install lnmp V1.6 completed! enjoy it.
12、其它
- LNMP安装选择的版本是:nginx-1.16.1+mysql-5.5.62+php-5.6.40+Enable InnoDB
- CentOS系统版本:CentOS Linux release 7.7.1908 (AltArch)
Filed under: 技术归总
0 Comments
1568 Views
Written by 正冰 on 2019, December 5, 11:41 PM
购买了一套美国Jetimpex公司运营的MotoCMS模板,模板平时卖199美元,碰上了黑五(Black Friday)和网络星期一(Cyber Monday),只花了109美元就买到了。
跟2个不同的销售聊过天,一个销售给了个0美元的inmotionhosting注册码(免费享受1个免费美国主机1年使用权+1个免费域名),另外一个销售说最低5美元可以享受。秉承节俭的原则,妥妥地用了第一个销售的注册码,注册完成后还要inmotionhosting人工审核,直接跟在线客服拉家常,10分钟后主机开通,域名也注册下来了。
然后我就把买到的这个模板放在了这个美国主机上(位于美国西海岸洛杉矶),一切顺利,可是速度不是很快。
然后我就把主机迁移到了国内服务器上,服务器上的web软件是Nginx,结果MotoCMS就开始“水土不服”了。二级页面都打不开,凭借多年经验我判断是需要给它上个重写规则(Rewrite Rules)。
懒人方法1:上google搜索,无果。
懒人方法2:反正花了钱,而且MotoCMS提供免费的技术支持,发了工单咨询一下,结果被踢皮球,让我找主机商把适用于Apache软件的.htaccess文件转化成适用于Nginx的。服务器都是我自行维护的,这不是让我找自己……
懒人方法3:把客服给的.htaccess扔到这个转换网址上(https://winginx.com/en/htaccess),得到了一个看似适用于Nginx的重写规则。结果还是不行。
最终,经过修改,适用于MotoCMS3在nginx下的重写规则(Rewrite Rules)来了……
- location / {
- if (!-e $request_filename){
- rewrite ^(.*)$ /index.php last;
- }
- }
Filed under: 技术归总
0 Comments
1522 Views
Written by 正冰 on 2019, October 26, 6:56 AM
有个网站是asp.net+mssql,要改版成php+mysql,要求原来网站里的文章都需要迁移到新网站,那么也就是要把原SQL Server的数据迁移到MySQL数据库。
虽然都是关系型数据库,但是还是有一定差异,最终操作过程如下:
1、备份原数据库(防止数据丢失);
2、比对新老数据库中数据表字段差异,将原数据库中的无用的字段直接删除,仅保留需要导入到新数据库表中的字段(数据);
3、使用Navicat这个万能数据库操作软件连接原数据库,导出原数据库的表数据,生成sql语句形式;
4、导出的sql语句文件都是insert into语句,也就是新增数据,通过Notepad++或者Sublime软件打开该文件替换相关的语句;
5、替换完成后保存,将该sql语句通过phpmyadmin导入至新数据库(请注意如果新数据库对应的表中某些字段是老数据库里没有的话,请设置一个默认值NULL防止因为导入的时候没默认值而失败)。
(完)
Filed under: 技术归总
0 Comments
1329 Views
Written by 正冰 on 2019, October 25, 8:05 AM
最近某个业务中服务器是windows 2003,因为这个服务器上还有其它服务,所以也没有重装它,只能安装能在这个系统上跑的最高php版本:PHP 5.4.45
而这个版本的PHP,无法支持最新的phpmyadmin,会提示:PHP 5.5+ is required. Currently installed version is: 5.4.45
解决方法1:升级PHP版本(这里是行不通的因为这个系统可以安装的最新版只能是5.4.45)
解决方法2:下载可以支持5.4.45的phpmyadmin。经过测试,最新的支持到5.4.45的phpmyadmin版本是2017-01-23发布的4.4.15.10。下载地址:https://files.phpmyadmin.net/phpMyAdmin/4.4.15.10/phpMyAdmin-4.4.15.10-all-languages.zip
修改它的配置,找到配置文件,位于libraries\config.default.php,包括主机地址$cfg['Servers'][$i]['host']和端口地址$cfg['Servers'][$i]['port']都可以定义。
Filed under: 技术归总
0 Comments
2809 Views
Written by 正冰 on 2019, October 8, 7:28 PM
最近使用ThinkPHP5.1在开发一套程序,之前的项目中大多数是后台管理程序,不需要在控制器里进行大量的数据库查询和调用。而这次因为这个程序是一个监控显示程序,需要在前台调取10+栏目的数据并且分别展示出来。
那么按照正常的思路就是在控制器的方法中写大量的查询语句并用assign函数绑定到模板变量中,然后再模板变量中用volist输出。
这样子操作太麻烦,因为要给这10+栏目的数据设置10个变量名(数组),而且模板中需要进行大量的修改。这样很不程序化……
怎么办呢?打开官方手册地址:https://www.kancloud.cn/manual/thinkphp5_1/354084
手册中给出了一个解决方法:直接使用函数设定数据集,而不需要在控制器中给模板变量赋值传入数据集变量。
那么怎么实现呢?
首先打开\application\common.php文件,写一个公用的调用函数,如下:
function G_data($type){
$list = Db::table('c')->where('type',$type)->where('status',1)->select();
return $list;
}
这个函数的意思是查询数据库中c表里符合status=1且type=传参的数据。
那么模板中怎么写?
{volist name=":G_data(0)" id="data"}
<p><a href="{$data.link}" target="_blank">{$data.name}</A></p>
{/volist}
这段代码的意思是查询type=0的数据并显示出它的链接link和内容name。
Filed under: 技术归总
0 Comments
1632 Views
Written by 正冰 on 2019, October 1, 11:56 PM
Filed under: 技术归总
0 Comments
966 Views