支持MySQL数据库,SPL升级到3.2
此文章主要讲述的是SPL升级到3.2全面支持MySQL数据库的实际应用与具体操作,如果你是MySQL数据库方面的新手,对MySQL数据库的相关实际应用不是很了解的话,以下的文章会给你提供更全面的知识。 SPL从上次的3.1.0.5开始,经过了一段时间,积累了一些修改并进
此文章主要讲述的是SPL升级到3.2全面支持MySQL数据库的实际应用与具体操作,如果你是MySQL数据库方面的新手,对MySQL数据库的相关实际应用不是很了解的话,以下的文章会给你提供更全面的知识。
SPL从上次的3.1.0.5开始,经过了一段时间,积累了一些修改并进行了MySQL数据库的支持,现在发布SPL版本为3.2.0.4,Dll下载地址:这里 。只需要在项目中,把原来的Dll覆盖即可,如果还没下载过SPL早期版本的朋友,本次SPL自上次发布的3.1.0.5以后进行的更新有:
1、支持MS SQL SERVER中的Bit型数据类型
映射到ClassMap中的类型为boolean,如:
<ol class="dp-xml"><li class="alt"><span><span class="tag"><span class="tag-name">attribute</span><span> </span><span class="attribute">name</span><span>=</span><span class="attribute-value">"IsOver"</span><span> </span><span class="attribute">column</span><span>=</span><span class="attribute-value">"IsOver"</span><span> </span><span class="attribute">type</span><span>=</span><span class="attribute-value">"boolean"</span><span> </span><span class="tag">/></span><span> </span></span></span></li></ol>
对应的实体类类型为bool型,如:
<ol class="dp-xml"> <li class="alt"><span><span>private bool m_IsOver; </span></span></li> <li><span>public bool IsOver </span></li> <li class="alt"><span>{ </span></li> <li><span>get </span></li> <li class="alt"><span>{ </span></li> <li><span>return this.m_IsOver; </span></li> <li class="alt"><span>} </span></li> <li><span>set </span></li> <li class="alt"><span>{ </span></li> <li> <span class="attribute">this.m_IsOver</span><span> = </span><span class="attribute-value">value</span><span>; </span> </li> <li class="alt"><span>} </span></li> <li><span>} </span></li> </ol>
在查询时可以通过Condition进行比较判断了:
<ol class="dp-xml"> <li class="alt"><span><span>Codition </span><span class="attribute">c</span><span>=.... </span></span></li> <li><span>c.AddEqualTo("IsOver",false); </span></li> </ol>
这会最终生成 IsOver='0'的查询条件
2、提供了对数据源的提供者类型的判断,这将方便区分不同的MySQL数据库提供者手动组装不同的SQL语句
用Setting.Instance().GetDatabaseVendor(dbName)根据dbName数据源取得数据源提供者,然后与DatabaseVendor枚举型比较
如Access的日期比较与Sql Server的不一致:一个采用#号,一个采用'号
<ol class="dp-xml"> <li class="alt"><span><span>if(Setting.Instance().GetDatabaseVendor(dbName)==DatabaseVendor.MsAccess) </span></span></li> <li><span>{ </span></li> <li class="alt"> <span>builder.Append(" and SpecialPriceD2.FromDate</span><span class="tag"><span>=#"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"#"); </span></span> </li> <li> <span>builder.Append(" and SpecialPriceD2.ToDate</span><span class="tag">></span><span>=#"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"#"); </span> </li> <li class="alt"><span>} </span></li> <li><span>if(Setting.Instance().GetDatabaseVendor(dbName)==DatabaseVendor.MsSqlServer) </span></li> <li class="alt"><span>{ </span></li> <li> <span>builder.Append(" and SpecialPriceD2.FromDate</span><span class="tag"><span>='"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"'"); </span></span> </li> <li class="alt"> <span>builder.Append(" and SpecialPriceD2.ToDate</span><span class="tag">></span><span>='"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"'"); </span> </li> <li><span>} </span></li> </ol>
这个功能将为系统对多种MySQL数据库的支持最佳的灵活性,虽然SPL本身的“实体”与“标准”都可以区分不同的数据源提供者,但在需要手写SQL的地方,也需要根据不同的数据源提供者提供不同的语句执行
3、修订了对所有保留字的兼容性
目前对所有的SPL中的操作,都加了定界符,ORACLE采用“"”号,MS的采用“[]”号,MySql的采用“`”号,所有测试都通过了
4、在Condition里添加了对Null值的查询功能
此方式只针对AddEqualTo()和AddNotEqualTo()有效:
<ol class="dp-xml"> <li class="alt"><span><span>c.AddEqualTo("字段名",System.DBNull.Value); </span></span></li> <li><span>c.AddNotEqualTo("字段名",System.DBNull.Value); </span></li> </ol>
5、增加了对MySql数据库的支持
SPL对MySql的访问连接采用的是MySql提供的专用.NET connector,此驱动应该说是目前.NET连接MySql的最佳选择,在使用SPL访问MySql时,只需要安装一下此驱动即可,下载与介绍请看
使用时只需要配置DatabaseMap时类型设为“MySql”即可,如下:
<ol class="dp-xml"> <li class="alt"><span><span class="tag"><span class="tag-name">database</span><span> </span><span class="attribute">name</span><span>=</span><span class="attribute-value">"MySqlDB"</span><span> </span><span class="attribute">type</span><span>=</span><span class="attribute-value">"MySql"</span><span class="tag">></span><span> </span></span></span></li> <li><span class="tag"><span class="tag-name">parameter</span><span> </span><span class="attribute">name</span><span>=</span><span class="attribute-value">"User Id"</span><span> </span><span class="attribute">value</span><span>=</span><span class="attribute-value">"root"</span><span class="tag">/></span><span> </span></span></li> <li class="alt"><span class="tag"><span class="tag-name">parameter</span><span> </span><span class="attribute">name</span><span>=</span><span class="attribute-value">"Data Source"</span><span> </span><span class="attribute">value</span><span>=</span><span class="attribute-value">"localhost"</span><span class="tag">/></span><span> </span></span></li> <li><span class="tag"><span class="tag-name">parameter</span><span> </span><span class="attribute">name</span><span>=</span><span class="attribute-value">"Database"</span><span> </span><span class="attribute">value</span><span>=</span><span class="attribute-value">"mysql"</span><span class="tag">/></span><span> </span></span></li> <li class="alt"><span class="tag"><span class="tag-name">parameter</span><span> </span><span class="attribute">name</span><span>=</span><span class="attribute-value">"password"</span><span> </span><span class="attribute">value</span><span>=</span><span class="attribute-value">""</span><span class="tag">/></span><span> </span></span></li> <li><span class="tag"><span class="tag-name">classMapFile</span><span> </span><span class="attribute">path</span><span>=</span><span class="attribute-value">"ClassMap.xml"</span><span> </span><span class="tag">/></span><span> </span></span></li> <li class="alt"> <span class="tag"></span><span class="tag-name">database</span><span class="tag">></span><span> </span> </li> </ol>
只需这里配置后,SPL在具体应用中与其他的完全一样,测试情况:
实体测试--->通过
RetrieveCriteira、UpdateCriteria、DeleteCriteria测试--->通过
Transaction测试--->通过
自动增长主键测试--->通过
TOP功能测试--->通过
6、对DateTime的Null值进行了处理 (3.2.0.1开始支持)
如果要对DateTime类型的字段赋于Null值,只需要使用DateTime.MinValue即可:
aEntity.CreateDate=DateTime.MinValue;
在SPL内部会判断如果DateTime.MinValue的话,自动保存到MySQL数据库为System.DBNull.Value,这就解决了不能给 DateTime类型直接赋于System.DBNull.Value的问题。
7、修订了UpdateCriteria对属性名与字段名不一致时导致的错误(3.2.0.2开始修订)
原来在UpdateCriteira时没有对属性进行转化为字段名,导致在属性名与字段名不一致的情况下会找不到字段。
(非常感谢iamsunrise提供的建议,请下载了SPL3.2的朋友重新下载一下)
(感谢子扬报出的BUG)
8、本3.2.0.4已经修复了DataBaseType的MySql类型了。

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Vous pouvez ouvrir PHPMYADMIN via les étapes suivantes: 1. Connectez-vous au panneau de configuration du site Web; 2. Trouvez et cliquez sur l'icône PHPMYADMIN; 3. Entrez les informations d'identification MySQL; 4. Cliquez sur "Connexion".

MySQL est un système de gestion de la base de données relationnel open source, principalement utilisé pour stocker et récupérer les données rapidement et de manière fiable. Son principe de travail comprend les demandes des clients, la résolution de requête, l'exécution des requêtes et les résultats de retour. Des exemples d'utilisation comprennent la création de tables, l'insertion et la question des données et les fonctionnalités avancées telles que les opérations de jointure. Les erreurs communes impliquent la syntaxe SQL, les types de données et les autorisations, et les suggestions d'optimisation incluent l'utilisation d'index, les requêtes optimisées et la partition de tables.

La position de MySQL dans les bases de données et la programmation est très importante. Il s'agit d'un système de gestion de base de données relationnel open source qui est largement utilisé dans divers scénarios d'application. 1) MySQL fournit des fonctions efficaces de stockage de données, d'organisation et de récupération, en prenant en charge les systèmes Web, mobiles et de niveau d'entreprise. 2) Il utilise une architecture client-serveur, prend en charge plusieurs moteurs de stockage et optimisation d'index. 3) Les usages de base incluent la création de tables et l'insertion de données, et les usages avancés impliquent des jointures multiples et des requêtes complexes. 4) Des questions fréquemment posées telles que les erreurs de syntaxe SQL et les problèmes de performances peuvent être déboguées via la commande Explication et le journal de requête lente. 5) Les méthodes d'optimisation des performances comprennent l'utilisation rationnelle des indices, la requête optimisée et l'utilisation des caches. Les meilleures pratiques incluent l'utilisation des transactions et des acteurs préparés

MySQL est choisi pour ses performances, sa fiabilité, sa facilité d'utilisation et son soutien communautaire. 1.MySQL fournit des fonctions de stockage et de récupération de données efficaces, prenant en charge plusieurs types de données et opérations de requête avancées. 2. Adoptez l'architecture client-serveur et plusieurs moteurs de stockage pour prendre en charge l'optimisation des transactions et des requêtes. 3. Facile à utiliser, prend en charge une variété de systèmes d'exploitation et de langages de programmation. 4. Avoir un solide soutien communautaire et fournir des ressources et des solutions riches.

Apache se connecte à une base de données nécessite les étapes suivantes: Installez le pilote de base de données. Configurez le fichier web.xml pour créer un pool de connexion. Créez une source de données JDBC et spécifiez les paramètres de connexion. Utilisez l'API JDBC pour accéder à la base de données à partir du code Java, y compris l'obtention de connexions, la création d'instructions, les paramètres de liaison, l'exécution de requêtes ou de mises à jour et de traitement des résultats.

L'installation de MySQL sur CENTOS implique les étapes suivantes: Ajout de la source MySQL YUM appropriée. Exécutez la commande YUM Install MySQL-Server pour installer le serveur MySQL. Utilisez la commande mysql_secure_installation pour créer des paramètres de sécurité, tels que la définition du mot de passe de l'utilisateur racine. Personnalisez le fichier de configuration MySQL selon les besoins. Écoutez les paramètres MySQL et optimisez les bases de données pour les performances.

Le processus de démarrage de MySQL dans Docker se compose des étapes suivantes: Tirez l'image MySQL pour créer et démarrer le conteneur, définir le mot de passe de l'utilisateur racine et mapper la connexion de vérification du port Créez la base de données et l'utilisateur accorde toutes les autorisations sur la base de données

PhPMyAdmin n'est pas seulement un outil de gestion de la base de données, il peut vous donner une compréhension approfondie de MySQL et améliorer les compétences en programmation. Les fonctions principales incluent l'exécution de la requête CRUD et SQL, et il est crucial de comprendre les principes des instructions SQL. Les conseils avancés incluent l'exportation / l'importation de données et la gestion des autorisations, nécessitant une compréhension approfondie de la sécurité. Les problèmes potentiels incluent l'injection SQL et la solution est des requêtes paramétrées et des sauvegardes. L'optimisation des performances implique l'optimisation des instructions SQL et l'utilisation de l'index. Les meilleures pratiques mettent l'accent sur les spécifications du code, les pratiques de sécurité et les sauvegardes régulières.
