千家信息网

Yii2中mssql和sql server数据库如何使用

发表于:2025-02-08 作者:千家信息网编辑
千家信息网最后更新 2025年02月08日,本篇文章给大家分享的是有关Yii2中mssql和sql server数据库如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.首先
千家信息网最后更新 2025年02月08日Yii2中mssql和sql server数据库如何使用

本篇文章给大家分享的是有关Yii2中mssql和sql server数据库如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

  1.首先找到yii2解析mssql的scheme:

  vendor/yiisoft/yii2/db/mssql/Schema.php

  2.更改解析代码:

  ⑴找到findColumns 的函数 大概在232行左右

  ⑵替代解析 代码如下 :

  /**

  * Collects the metadata of table columns.

  * @param TableSchema $table the table metadata

  * @return boolean whether the table exists in the database

  */

  protected function findColumns($table)

  {

  $pdo = $this->db->getSlavePdo();

  $version = explode('.', $pdo->getAttribute(\PDO::ATTR_SERVER_VERSION));

  //var_dump($version);exit;

  if (intval($version[0]<9)) {   $sql = <<   SELECT   column_name = a.name,   is_identity = case when exists(SELECT 1 FROM sysobjects where xtype='PK' and parent_obj=a.id and name in (   SELECT name FROM sysindexes WHERE indid in(   SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid))) then 1 else 0 end,   data_type = case   when b.name in ('ntext','datetime') then b.name   when isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0)>0 then

  b.name + '(' + convert(varchar(20), COLUMNPROPERTY(a.id,a.name,'PRECISION')) + ','+convert(varchar(10), COLUMNPROPERTY(a.id,a.name,'Scale'))+')'

  else b.name + '(' + convert(varchar(20), COLUMNPROPERTY(a.id,a.name,'PRECISION')) + ')' end ,

  is_nullable = case when a.isnullable=1 then 'Yes' else 'No' end,

  column_default = isnull(e.text,''),

  comment = isnull(g.[value],'')

  FROM

  syscolumns a

  left join

  systypes b

  on

  a.xusertype=b.xusertype

  inner join

  sysobjects d

  on

  a.id=d.id and d.xtype='U' and d.name<>'dtproperties'

  left join

  syscomments e

  on

  a.cdefault=e.id

  left join

  sysproperties g

  on

  a.id=g.id and a.colid=g.smallid

  left join

  sysproperties f

  on

  d.id=f.id and f.smallid=0

  where

  d.name='{$table->fullName}'

  order by

  a.id,a.colorder

  SQL2000;

  }

  else {

  $columnsTableName = 'INFORMATION_SCHEMA.COLUMNS';

  $whereSql = "[t1].[table_name] = '{$table->name}'";

  if ($table->catalogName !== null) {

  $columnsTableName = "{$table->catalogName}.{$columnsTableName}";

  $whereSql .= " AND [t1].[table_catalog] = '{$table->catalogName}'";

  }

  if ($table->schemaName !== null) {

  $whereSql .= " AND [t1].[table_schema] = '{$table->schemaName}'";

  }

  $columnsTableName = $this->quoteTableName($columnsTableName);

  $sql = <<   SELECT   [t1].[column_name], [t1].[is_nullable], [t1].[data_type], [t1].[column_default],   COLUMNPROPERTY(OBJECT_ID([t1].[table_schema] + '.' + [t1].[table_name]), [t1].[column_name], 'IsIdentity') AS is_identity,   CONVERT(VARCHAR, [t2].[value]) AS comment   FROM {$columnsTableName} AS [t1]   LEFT OUTER JOIN [sys].[extended_properties] AS [t2] ON   [t2].[minor_id] = COLUMNPROPERTY(OBJECT_ID([t1].[TABLE_SCHEMA] + '.' + [t1].[TABLE_NAME]), [t1].[COLUMN_NAME], 'ColumnID') AND   OBJECT_NAME([t2].[major_id]) = [t1].[table_name] AND   [t2].[class] = 1 AND   [t2].[class_desc] = 'OBJECT_OR_COLUMN' AND   [t2].[name] = 'MS_Description'   WHERE {$whereSql}   SQL;   }   try {   $columns = $this->db->createCommand($sql)->queryAll();

  if (empty($columns)) {

  return false;

  }

  } catch (\Exception $e) {

  return false;

  }

  foreach ($columns as $column) {

  $column = $this->loadColumnSchema($column);

  foreach ($table->primaryKey as $primaryKey) {

  if (strcasecmp($column->name, $primaryKey) === 0) {

  $column->isPrimaryKey = true;

  break;

  }

  }

  if ($column->isPrimaryKey && $column->autoIncrement) {

  $table->sequenceName = '';

  }

  $table->columns[$column->name] = $column;

  }

  return true;

  }

  3.分析这段代码:

  ⑴获取数据库的版本:

  $pdo = $this->db->getSlavePdo();

  $version = explode('.', $pdo->getAttribute(\PDO::ATTR_SERVER_VERSION));

  ⑵根据版本解析:

  if (intval($version[0]<9)) { }else{}   ⑶解析sql2000:   $sql = <<   SELECT   column_name = a.name,   is_identity = case when exists(SELECT 1 FROM sysobjects where xtype='PK' and parent_obj=a.id and name in (   SELECT name FROM sysindexes WHERE indid in(   SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid))) then 1 else 0 end,   data_type = case   when b.name in ('ntext','datetime') then b.name   when isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0)>0 then

  b.name + '(' + convert(varchar(20), COLUMNPROPERTY(a.id,a.name,'PRECISION')) + ','+convert(varchar(10), COLUMNPROPERTY(a.id,a.name,'Scale'))+')'

  else b.name + '(' + convert(varchar(20), COLUMNPROPERTY(a.id,a.name,'PRECISION')) + ')' end ,

  is_nullable = case when a.isnullable=1 then 'Yes' else 'No' end,

  column_default = isnull(e.text,''),

  comment = isnull(g.[value],'')

  FROM

  syscolumns a

  left join

  systypes b

  on

  a.xusertype=b.xusertype

  inner join

  sysobjects d

  on

  a.id=d.id and d.xtype='U' and d.name<>'dtproperties'

  left join

  syscomments e

  on

  a.cdefault=e.id

  left join

  sysproperties g

  on

  a.id=g.id and a.colid=g.smallid

  left join

  sysproperties f

  on

  d.id=f.id and f.smallid=0

  where

  d.name='{$table->fullName}'

  order by

  a.id,a.colorder

  SQL2000;

  ⑷else 就是原来的解析方式 3.打开sql的数据库scheme的缓存,在db.php文件中添加 :'enableSchemaCache'=>true 既可以。

以上就是Yii2中mssql和sql server数据库如何使用,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。

数据 数据库 代码 就是 更多 版本 知识 篇文章 g. 实用 函数 工作会 文件 文章 方式 看吧 知识点 缓存 行业 详情 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 服务器锁定和管理怎么解决 数据库之前数据传输 网络安全和信息化四个强化 数据库应用技术视频 广州新一代网络技术开发展示 手游新武林外传人多的服务器 关系型数据库的三大范式指什么 云南装修网络安全 上海炬瞳软件开发有限公司 图文管理服务器 倒计时器软件开发 想找软件开发 网络安全教育心得小学 网络安全教育直播回放 河南电力应急软件开发应用 三台路由器怎么连接服务器 sqlplus导出数据库 电脑输入网络安全密钥处是灰的 端口的http服务器 邵阳学院数据库技术与应用教学 国服1.9服务器地址 数据库从后台到前端页面展示 网络安全设备管理类专业 普陀区工商软件开发售后服务 华为云服务器防火墙转发配置 中国学位论文全文数据库网址 方舟服务器地图怎么换 人才数据库证件类型有哪几种 涛思数据库bug 成都软件开发学校哪个好
0