【自己搭建商城源码】【懒人修仙源码】【央驰源码】ibatis 源码 时间

2024-12-23 03:10:56 来源:网站源码 可以干嘛 分类:探索

1.mybatis和ibatis的区别
2.ibatis 源码是什么
3.c#读取Config文件的问题
4.class path resource [ibatis.xml] cannot be opened because it does not exist
5.ibatis起源

ibatis 源码 时间

mybatis和ibatis的区别

       1、基本信息不同

       mybatis:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。

       MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。

       ibatis:iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO),同时还提供一个利用这个框架开发的JPetStore实例。相对Hibernate和ApacheOJB等“一站式”ORM解决方案而言,ibatis 是一种“半自动化”的ORM实现。

       iBATIS 目前提供了三种语言实现的版本,包括:Java、.NET以及Ruby。

       2、开发时间不同

       mybatis:MyBatis 本是apache的一个开源项目iBatis, 年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。年月迁移到Github。

       ibatis:iBATIS一词来源于“internet”和“abatis”的组合,是一个由Clinton Begin在年发起的开放源代码项目。

       3、配置方法不同

       mybatis简化了编码的过程,不需要去写dao的实现类,直接写一个dao的接口,再写一个xml配置文件,整个mybatis就配置好了,也就是数据库就连接好了,然后在service里面直接调用dao就可以了,但是ibatis则不可以,必须要写dao的实现类。mybatis是ibatis的升级版本。

       å‚考资料:百度百科-mybatis

       å‚考资料:百度百科-ibatis

ibatis 是什么

       iBATIS一词来源于“internet”和“abatis”的组合,是时间一个由Clinton Begin在年发起的开放源代码项目。最初侧重于密码软件的源码开发,现在是时间一个基于Java的持久层框架。

c#读取Config文件的源码自己搭建商城源码问题

       应用程序配置文件(App.config)是标准的 XML 文件,XML 标记和属性是时间懒人修仙源码区分大小写的。它是源码可以按需要更改的,开发人员可以使用配置文件来更改设置,时间而不必重编译应用程序。源码

       对于一个config文件:

       <?时间xml version="1.0" encoding="utf-8" ?>

       <configuration>

        <appSettings>

        <add key="ServerIP" value=".0.0.1"></add>

        <add key="DataBase" value="WarehouseDB"></add>

        <add key="user" value="sa"></add>

        <add key="password" value="sa"></add>

        </appSettings>

       </configuration>

       对config配置文件的读写类:

       using System;

       using System.Collections.Generic;

       using System.Linq;

       using System.Text;

       using System.Text.RegularExpressions;

       using System.Configuration;

       using System.ServiceModel;

       using System.ServiceModel.Configuration;

       namespace NetUtilityLib

       {

        public static class ConfigHelper

        {

        //依据连接串名字connectionName返回数据连接字符串

        public static string GetConnectionStringsConfig(string connectionName)

        {

        //指定config文件读取

        string file = System.Windows.Forms.Application.ExecutablePath;

        System.Configuration.Configuration config = ConfigurationManager.OpenExeConfiguration(file);

        string connectionString =

        config.ConnectionStrings.ConnectionStrings[connectionName].ConnectionString.ToString();

        return connectionString;

        }

        ///<summary>

        ///更新连接字符串

        ///</summary>

        ///<param name="newName">连接字符串名称</param>

        ///<param name="newConString">连接字符串内容</param>

        ///<param name="newProviderName">数据提供程序名称</param>

        public static void UpdateConnectionStringsConfig(string newName, string newConString, string newProviderName)

        {

        //指定config文件读取

        string file = System.Windows.Forms.Application.ExecutablePath;

        Configuration config = ConfigurationManager.OpenExeConfiguration(file);

        bool exist = false; //记录该连接串是否已经存在

        //如果要更改的连接串已经存在

        if (config.ConnectionStrings.ConnectionStrings[newName] != null)

        {

        exist = true;

        }

        // 如果连接串已存在,首先删除它

        if (exist)

        {

        config.ConnectionStrings.ConnectionStrings.Remove(newName);

        }

        //新建一个连接字符串实例

        ConnectionStringSettings mySettings =

        new ConnectionStringSettings(newName,源码 newConString, newProviderName);

        // 将新的连接串添加到配置文件中.

        config.ConnectionStrings.ConnectionStrings.Add(mySettings);

        // 保存对配置文件所作的更改

        config.Save(ConfigurationSaveMode.Modified);

        // 强制重新载入配置文件的ConnectionStrings配置节

        ConfigurationManager.RefreshSection("ConnectionStrings");

        }

        ///<summary>

        ///返回*.exe.config文件中appSettings配置节的value项

        ///</summary>

        ///<param name="strKey"></param>

        ///<returns></returns>

        public static string GetAppConfig(string strKey)

        {

        string file = System.Windows.Forms.Application.ExecutablePath;

        Configuration config = ConfigurationManager.OpenExeConfiguration(file);

        foreach (string key in config.AppSettings.Settings.AllKeys)

        {

        if (key == strKey)

        {

        return config.AppSettings.Settings[strKey].Value.ToString();

        }

        }

        return null;

        }

        ///<summary>

        ///在*.exe.config文件中appSettings配置节增加一对键值对

        ///</summary>

        ///<param name="newKey"></param>

        ///<param name="newValue"></param>

        public static void UpdateAppConfig(string newKey, string newValue)

        {

        string file = System.Windows.Forms.Application.ExecutablePath;

        Configuration config = ConfigurationManager.OpenExeConfiguration(file);

        bool exist = false;

        foreach (string key in config.AppSettings.Settings.AllKeys)

        {

        if (key == newKey)

        {

        exist = true;

        }

        }

        if (exist)

        {

        config.AppSettings.Settings.Remove(newKey);

        }

        config.AppSettings.Settings.Add(newKey, newValue);

        config.Save(ConfigurationSaveMode.Modified);

        ConfigurationManager.RefreshSection("appSettings");

        }

        // 修改system.serviceModel下所有服务终结点的IP地址

        public static void UpdateServiceModelConfig(string configPath, string serverIP)

        {

        Configuration config = ConfigurationManager.OpenExeConfiguration(configPath);

        ConfigurationSectionGroup sec = config.SectionGroups["system.serviceModel"];

        ServiceModelSectionGroup serviceModelSectionGroup = sec as ServiceModelSectionGroup;

        ClientSection clientSection = serviceModelSectionGroup.Client;

        foreach (ChannelEndpointElement item in clientSection.Endpoints)

        {

        string pattern = @"\b\d{ 1,3}\.\d{ 1,3}\.\d{ 1,3}\.\d{ 1,3}\b";

        string address = item.Address.ToString();

        string replacement = string.Format("{ 0}", serverIP);

        address = Regex.Replace(address, pattern, replacement);

        item.Address = new Uri(address);

        }

        config.Save(ConfigurationSaveMode.Modified);

        ConfigurationManager.RefreshSection("system.serviceModel");

        }

        // 修改applicationSettings中App.Properties.Settings中服务的IP地址

        public static void UpdateConfig(string configPath, string serverIP)

        {

        Configuration config = ConfigurationManager.OpenExeConfiguration(configPath);

        ConfigurationSectionGroup sec = config.SectionGroups["applicationSettings"];

        ConfigurationSection configSection = sec.Sections["DataService.Properties.Settings"];

        ClientSettingsSection clientSettingsSection = configSection as ClientSettingsSection;

        if (clientSettingsSection != null)

        {

        SettingElement element1 = clientSettingsSection.Settings.Get("DataService_SystemManagerWS_SystemManagerWS");

        if (element1 != null)

        {

        clientSettingsSection.Settings.Remove(element1);

        string oldValue = element1.Value.ValueXml.InnerXml;

        element1.Value.ValueXml.InnerXml = GetNewIP(oldValue, serverIP);

        clientSettingsSection.Settings.Add(element1);

        }

        SettingElement element2 = clientSettingsSection.Settings.Get("DataService_EquipManagerWS_EquipManagerWS");

        if (element2 != null)

        {

        clientSettingsSection.Settings.Remove(element2);

        string oldValue = element2.Value.ValueXml.InnerXml;

        element2.Value.ValueXml.InnerXml = GetNewIP(oldValue, serverIP);

        clientSettingsSection.Settings.Add(element2);

        }

        }

        config.Save(ConfigurationSaveMode.Modified);

        ConfigurationManager.RefreshSection("applicationSettings");

        }

        private static string GetNewIP(string oldValue, string serverIP)

        {

        string pattern = @"\b\d{ 1,3}\.\d{ 1,3}\.\d{ 1,3}\.\d{ 1,3}\b";

        string replacement = string.Format("{ 0}", serverIP);

        string newvalue = Regex.Replace(oldValue, pattern, replacement);

        return newvalue;

        }

        }

       }

       测试代码如下:

        class Program

        {

        static void Main(string[] args)

        {

        try

        {

        //string file = System.Windows.Forms.Application.ExecutablePath + ".config";

        //string file1 = AppDomain.CurrentDomain.SetupInformation.ConfigurationFile;

        string serverIP = ConfigHelper.GetAppConfig("ServerIP");

        string db = ConfigHelper.GetAppConfig("DataBase");

        string user = ConfigHelper.GetAppConfig("user");

        string password = ConfigHelper.GetAppConfig("password");

        Console.WriteLine(serverIP);

        Console.WriteLine(db);

        Console.WriteLine(user);

        Console.WriteLine(password);

        ConfigHelper.UpdateAppConfig("ServerIP", "..1.");

        string newIP = ConfigHelper.GetAppConfig("ServerIP");

        Console.WriteLine(newIP);

        Console.ReadKey();

        }

        catch (Exception ex)

        {

        Console.WriteLine(ex.Message);

        }

        }

        }

class path resource [ibatis.xml] cannot be opened because it does not exist

       å› ä¸ºåˆ†ç±»è·¯å¾„资源 [ibatis.xml] 不存在,因此不能打开。

       æ³¨ï¼š

        ibatis xml 分别指“ibatis 持久层框架”和“可扩展标记语言”

        ibatis 来源于“internet” 和“abatis” 的组合,是一个由 Clinton Begin 在年发起的开放源代码项目,现在是基于Java 的持久层框架。 

ibatis起源

       IBatis,作为一款“半自动化”的时间ORM框架,起源于对传统“一站式”解决方案如Hibernate和Apache OJB的源码央驰源码补充。它提供SQL Maps和Data Access Objects(DAO)的时间功能,以及一个用于实践的源码示例——JPetStore。

       与Hibernate和OJB不同,IBatis并未完全封装数据库结构,大漠封装源码而是留给开发者更多自由,需要程序员自己编写SQL。这在一定程度上保留了对SQL的控制,适合那些有特定需求的遥感潮源码场景,比如:

       系统设计要求对部分或全部数据保密,仅提供有限的SQL接口。

       业务逻辑需在数据库层面通过存储过程实现,如金融行业的规定。

       面对高并发和高性能要求,需要精细调整和优化SQL语句。

       然而,当面临这些需求时,Hibernate的全面自动化可能不再适用,使用JDBC虽然可以解决问题,但编写冗长的数据库访问代码和手动处理字段读取则显得繁琐。因此,IBatis在这些特定场景下,提供了一种平衡自动化与灵活性的解决方案。

扩展资料

       iBATIS一词来源于“internet”和“abatis”的组合,是一个由Clinton Begin在年发起的开放源代码项目。最初侧重于密码软件的开发,现在是一个基于Java的持久层框架。

本文地址:http://50.net.cn/html/46d605693897.html 欢迎转发