您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

详解php7如何连接使用dm数据库(图文)

2024/4/18 2:42:06发布21次查看
本文由php7教程栏目给大家介绍关于php7.2是如何连接使用达梦(dm)数据库的,希望对需要的朋友有所帮助!前言公司要搞国产化开发,数据库选用达梦数据库,达梦版本为dm8,php版本为7.2,前期在windows进行开发。
数据库从mysql迁移到达梦数据库里面,迁移方法和php的扩展安装方法就不讲了,这方面网上的资料还蛮多。
不过php连接达梦数据库之后的使用操作的资料就比较少了,客服的技术大家都懂的,资料全靠翻文档,简单给大家提供一下我踩过的坑,方法都是直接操作数据库,后续根据大家自己的喜好去封装去吧。
简单说明一下达梦的资料目录,在达梦的安装目录下面的《doc》里面主要是各种使用文档,《drivers》里面是各种语言的扩展,php的so扩展就是从这里面取的,我这里主要使用的是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  查询结果:</br>;while ($line = dm_fetch_array($result)){    print_r($line);    echo '<br>';}/* 释放资源 */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 t1left join ( select min(employee_id) as minid,job_id from dmhr.employee group by job_id ) t2 on t2.job_id=t1.job_idwhere t1.employee_id in (select min(employee_id) as minid from dmhr.employee group by job_id);
结语目前踩过的坑就这些了,希望能够帮助到大家。
对于其他问题还是要多翻阅官方文档了。
以上就是详解php7如何连接使用dm数据库(图文)的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product