php7怎么连接使用dm数据库
这篇文章主要介绍“php7怎么连接使用dm数据库”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php7怎么连接使用dm数据库”文章能帮助大家解决问题。
创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、做网站、花都网络推广、微信小程序定制开发、花都网络营销、花都企业策划、花都品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供花都建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
前言
这里主要使用的是php_dm的扩展,pdo_dm的资料太少了我就没怎么研究。
实例化数据库的时候有两点需要提醒各位的,字符集和字符串大小写敏感记得提前设置好,不要给自己挖坑。
本人经历就是MySQL迁移过来的数据表名和字段名都是小写,结果在后面使用的时候各种坑,后来发现大小写敏感去掉就可以了。
这里就用官方的示例库里面的CITY这张表演示php7.2各种使用方法吧。
查询
废话不多说,先上代码
//连接数据库 $link = dm_connect("localhost", "SYSDBA", "SYSDBA"); if(!$link){ var_dump(@dm_error()); var_dump(iconv("GBK","UTF-8",@dm_errormsg())); } dm_setoption($link,1,12345,1);//设置 dm 连接和语句的相关属性,设置UTF8 $query = "select * from DMHR.CITY"; $result = dm_exec($link,$query); print " 查询结果:"; while ($line = dm_fetch_array($result)){ print_r($line); echo '
'; } /* 释放资源 */ dm_free_result($result); /* 断开连接 */ dm_close($link);
达梦的php官方扩展php5和php7的使用方法区别很大,php5里面很多方法在php7里面用不了,部分方法在php7里面用其他方法替代了,网上的资料大部分都是php5的,在php7里面完全用不了。
查询语句出来的中文乱码的问题就是一个天坑,查了半天文档才试出来的这种方法,有其他更优雅的方法也欢迎教一下我,大家互相学习。
插入
//连接数据库 $link = dm_connect("localhost", "SYSDBA", "SYSDBA"); if(!$link){ var_dump(@dm_error()); var_dump(iconv("GBK","UTF-8",@dm_errormsg())); } dm_setoption($link,1,12345,1);//设置 dm 连接和语句的相关属性,设置UTF8 $query = "INSERT INTO DMHR.CITY (CITY_ID,CITY_NAME,REGION_ID) VALUES ('JL','吉林','1')"; $result = dm_exec($link,$query); if($result){ echo "插入成功"; //曲线查询插入id /*$query = "SELECT @@IDENTITY as insert_id"; $result = dm_exec($link,$query); $line = dm_fetch_array($result); echo ',ID:'; print_r($line);*/ } /* 释放资源 */ dm_free_result($result); /* 断开连接 */ dm_close($link);
官方提供的dm_insert_id()这个函数貌似只用php5能用,php7没有这个函数,只能通过曲线查询自增的id值,当然演示的这张表没有自增ID,同时SELECT @@IDENTITY as insert_id 这句是必定查询成功的,就算插入失败也会返回更前一次插入成功的自增ID,千万不要用自增ID判断语句是否插入成功。
更新
//连接数据库 $link = dm_connect("localhost", "SYSDBA", "SYSDBA"); if(!$link){ var_dump(@dm_error()); var_dump(iconv("GBK","UTF-8",@dm_errormsg())); } dm_setoption($link,1,12345,1);//设置 dm 连接和语句的相关属性,设置UTF8 $query = "UPDATE DMHR.CITY SET REGION_ID='2' WHERE CITY_ID='JL'"; $result = dm_exec($link,$query); if($result){ echo "更新成功"; } /* 释放资源 */ dm_free_result($result); /* 断开连接 */ dm_close($link);
更新就很简单了
删除
//连接数据库 $link = dm_connect("localhost", "SYSDBA", "SYSDBA"); if(!$link){ var_dump(@dm_error()); var_dump(iconv("GBK","UTF-8",@dm_errormsg())); } dm_setoption($link,1,12345,1);//设置 dm 连接和语句的相关属性,设置UTF8 $query = "DELETE FROM DMHR.CITY WHERE (CITY_ID='JL')"; $result = dm_exec($link,$query); if($result){ echo "删除成功"; } /* 释放资源 */ dm_free_result($result); /* 断开连接 */ dm_close($link);
删除也很简单,没什么特别注意的地方
事务
根据官方文档介绍:“DM 没有提供显式定义事务开始的语句,第一个可执行的 SQL 语句(除登录语句外)隐含事务的开始”,这是没有定义事务开始方法的原因,不过当我们要从某一段程序开始事务的时候,可以使用dm_autocommit()函数将事务的自动提交关闭,在程序结束之后在将自动提交打开
//连接数据库 $link = dm_connect("localhost", "SYSDBA", "SYSDBA"); if(!$link){ var_dump(@dm_error()); var_dump(iconv("GBK","UTF-8",@dm_errormsg())); } dm_setoption($link,1,12345,1);//设置 dm 连接和语句的相关属性,设置UTF8 $query = "INSERT INTO DMHR.CITY (CITY_ID,CITY_NAME,REGION_ID) VALUES ('JL','吉林','1')"; $result = dm_exec($link,$query); if($result){ echo "插入成功。"; } $result = dm_autocommit($link,false);//事务自动提交关闭 $query = "UPDATE DMHR.CITY SET CITY_NAME='辽宁' WHERE (CITY_ID='SY')"; $result = dm_exec($link,$query); if($result){ echo "更新成功,回滚。"; } dm_rollback($link);//回滚 //dm_commit($link);//提交 $result = dm_autocommit($link,true);//开启事务自动提交,结束事务 /* 断开连接 */ dm_close($link);
踩过的坑
一、在数据库中获取时间戳格式的时间select DATEDIFF(s, '1970-01-01 00:00:00', GETUTCDATE());
二、如果之前使用的数据库是mysql,时间格式 DATETIME 和 TIMESTAMP 这两种类型后面的标度要注意一下,如果不是0的话时间精度会更长
三、有些字段查询出来的话会变成大写,比如“count”
解决方法:将字段用双引号引上例:select count(1) as "count" from "DMHR"."CITY";
四、group by语句的使用很严格(或者说mysql的group by过于放松),select中除聚合函数之外出现的所有字段必须要在group by里面。
比方举一个错误的例子:
select EMPLOYEE_NAME,JOB_ID from "DMHR"."EMPLOYEE" group by JOB_ID;
EMPLOYEE_NAME和字段没在group by 中,执行必定失败
提供一种解决思路:
select * from "DMHR"."EMPLOYEE" where EMPLOYEE_ID in (select min(EMPLOYEE_ID) as minid from "DMHR"."EMPLOYEE" group by JOB_ID)
同样select中如果有聚合函数之外的字段,需要加入group by。错误的例子:
select min(EMPLOYEE_ID),EMPLOYEE_NAME,JOB_ID from "DMHR"."EMPLOYEE";
select中有min()函数外还有其他字段,执行必定失败。
如果一定要在其他很多字段里面加入聚合函数,提供一种思路:
select t1.EMPLOYEE_NAME,t1.JOB_ID,t2.minid from "DMHR"."EMPLOYEE" t1 left join ( select min(EMPLOYEE_ID) as minid,JOB_ID from "DMHR"."EMPLOYEE" group by JOB_ID ) t2 on t2.JOB_ID=t1.JOB_ID where t1.EMPLOYEE_ID in (select min(EMPLOYEE_ID) as minid from "DMHR"."EMPLOYEE" group by JOB_ID);
关于“php7怎么连接使用dm数据库”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注创新互联行业资讯频道,小编每天都会为大家更新不同的知识点。
新闻名称:php7怎么连接使用dm数据库
分享URL:http://myzitong.com/article/pcihgc.html