深入理解Mybatis之配置文件详解_imapperext-程序员宅基地

技术标签: Mybatis配置文件  JavaEE  Mybatis配置文件详解  深入理解Mybatis  Mybatis  

1.  Mybatis配置文件详解

1.1. 全局配置文件内容

SqlMapConfig.xml的配置内容和顺序如下(顺序不能乱):

Properties(属性)

Settings(全局参数设置)

typeAliases(类型别名)

typeHandlers(类型处理器)

objectFactory(对象工厂)

plugins(插件)

environments(环境信息集合)

       environment(单个环境信息)

              transactionManager(事物)

              dataSource(数据源)

mappers(映射器)

1.1.1.  Properties

SqlMapConfig.xml文件中可以引用java属性文件中的配置信息

db.properties配置信息如下:

db.driver=com.mysql.jdbc.Driver

db.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf8

db.username=root

db.password=root

SqlMapConfig.xml使用properties标签后,如下所示:

<!-- 通过properties标签,读取java配置文件的内容 -->

<properties resource="db.properties" />

 

<!-- 配置mybatis的环境信息 -->

<environments default="development">

    <environment id="development">

        <!-- 配置JDBC事务控制,由mybatis进行管理 -->

        <transactionManager type="JDBC"></transactionManager>

        <!-- 配置数据源,采用dbcp连接池 -->

        <dataSource type="POOLED">

            <property name="driver"value="${db.driver}"/>

            <property name="url"value="${db.url}"/>

            <property name="username"value="${db.username}"/>

            <property name="password"value="${db.password}"/>

        </dataSource>

    </environment>

</environments>

使用${},可以引用已经加载的java配置文件中的信息。

注意:mybatis将按照下面的顺序加载属性:

u  Properties标签体内定义的属性首先被读取

u  Properties引用的属性会被读取,如果发现上面已经有同名的属性了,那后面会覆盖前面的值

u  parameterType接收的值会最后被读取,如果发现上面已经有同名的属性了,那后面会覆盖前面的值

 

所以说,mybatis读取属性的顺序由高到低分别是:parameterType接收的属性值、properties引用的属性、properties标签内定义的属性。

1.1.2.  Settings

mybatis全局配置参数,全局参数将会影响mybatis的运行行为。

 

详细参见“mybatis学习资料/mybatis-settings.xlsx”文件

1.1.3.  typeAliases

别名是使用是为了在映射文件中,更方便的去指定入参和结果集的类型,不再用写很长的一段全限定名。

1.1.3.1.      mybatis支持的别名

别名

映射的类型

_byte

byte

_long

long

_short

short

_int

int

_integer

int

_double

double

_float

float

_boolean

boolean

string

String

byte

Byte

long

Long

short

Short

int

Integer

integer

Integer

double

Double

float

Float

boolean

Boolean

date

Date

decimal

BigDecimal

bigdecimal

BigDecimal

 

1.1.3.2.      自定义别名

SqlMapConfig.xml配置信息如下:

<!-- 定义别名 -->

    <typeAliases>

        <!-- 单个定义别名 -->

        <typeAlias type="cn.itcast.mybatis.po.User" alias="user"/>

       

        <!-- 批量定义别名(推荐) -->

        <!-- [name]:指定批量定义别名的类包,别名为类名(首字母大小写都可) -->

        <package name="cn.itcast.mybatis.po"/>

    </typeAliases>

1.1.4.  Mappers

1.1.4.1.      <mapper resource=’’/>

使用相对于类路径的资源

如:<mapperresource="sqlmap/User.xml" />

1.1.4.2.      <mapper url=’’/>

使用完全限定路径

如:<mapperurl="file:///D:\workspace_spingmvc\mybatis_01\config\sqlmap\User.xml"/>

1.1.4.3.      <mapper class=’’/>

使用mapper接口的全限定名

如:<mapperclass="cn.itcast.mybatis.mapper.UserMapper"/>

注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下

1.1.4.4.      <package name=’’/>(推荐)

注册指定包下的所有映射文件

如:<package name="cn.itcast.mybatis.mapper"/>

 

注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下

1.2. Mybatis映射文件

1.2.1.  输入映射

1.2.1.1.      ParameterType

指定输入参数的java类型,可以使用别名或者类的全限定名。它可以接收简单类型、POJO、HashMap。

1.2.1.1.1.    传递简单类型

参考入门需求:根据用户ID查询用户信息。

1.2.1.1.2.    传递POJO对象

参考入门需求:添加用户。

1.2.1.1.3.    传递POJO包装对象

开发中通过pojo传递查询条件 ,查询条件是综合的查询条件,不仅包括用户查询条件还包括其它的查询条件(比如将用户购买商品信息也作为查询条件),这时可以使用包装对象传递输入参数。

1、需求:

 综合查询用户信息,需要传入查询条件复杂,比如(用户信息、订单信息、商品信息)。

2、定义包装类对象

一般User.java类要和数据表表字段一致,最好不要在这里面添加其他字段,第二天学习mybatis的逆向工程时,会根据表结构,生成po类,如果在po类中扩展字段,此时会被覆盖掉。

所以针对要扩展的po类,我们需要创建一个扩展类,来继承它。

定义POJO包装类:

3、编写Mapper接口

 //通过包装类来进行复杂的用户信息综合查询

public List<UserExt>findUserList(UserQueryVO userQueryVO);

4、编写Mapper映射文件

  <!-- 通过包装类来进行复杂的用户信息综合查询 -->

<select id="findUserList" parameterType="userQueryVO" resultType="userExt">

        SELECT* FROM USER WHERE sex=#{userExt.sex} AND username LIKE'%${userExt.username}%'

</select>

 

5、编写测试代码

  @Test

publicvoid findUserListTest() {

    // 创建SqlSession

    SqlSession sqlSession = sqlSessionFactory.openSession();

    // 通过SqlSession,获取mapper接口的动态代理对象

    UserMapper userMapper =sqlSession.getMapper(UserMapper.class);

 

    //构造userQueryVO对象

    UserQueryVO userQueryVO = new UserQueryVO();

       

    // 构造UserExt对象

    UserExt userExt = new UserExt();

    userExt.setSex("1");

    userExt.setUsername("小明");

       

    userQueryVO.setUserExt(userExt);

 

    // 调用mapper对象的方法

    List<UserExt> list =userMapper.findUserList(userQueryVO);

 

    System.out.println(list);

    // 关闭SqlSession

    sqlSession.close();

}

1.2.1.2.      传递HashMap

同传递POJO对象一样,mapkey相当于pojo的属性

1、映射文件

<!-- 传递hashmap综合查询用户信息 -->

   <select id="findUserByHashmap" parameterType="hashmap" resultType="user">

     select * from user where id=#{ id} and username like '%${ username}%'

   </select>

上边红色标注的是hashmap的key。

2、测试代码

Public void testFindUserByHashmap()throws Exception{

      //获取session

      SqlSessionsession = sqlSessionFactory.openSession();

      //获限mapper接口实例

      UserMapperuserMapper = session.getMapper(UserMapper.class);

      //构造查询条件Hashmap对象

      HashMap<String,Object> map = new HashMap<String, Object>();

      map.put("id", 1);

      map.put("username", "管理员");

     

      //传递Hashmap对象查询用户列表

      List<User>list= userMapper.findUserByHashmap(map);

      //关闭session

      session.close();

   }

 

 

异常测试:

传递的map中的key和sql中解析的key不一致。

测试结果没有报错,只是通过key获取值为空。

 

1.2.2.  输出映射

1.2.2.1.      resultType

使用resultType进行结果映射时,需要查询出的列名和映射的对象的属性名一致,才能映射成功。

 

如果查询的列名和对象的属性名全部不一致,那么映射的对象为空。

如果查询的列名和对象的属性名有一个一致,那么映射的对象不为空,但是只有映射正确那一个属性才有值。

 

如果查询的sql的列名有别名,那么这个别名就是和属性映射的列名。

1、使用方法

 使用resultType进行结果映射时,查询的列名和映射的pojo属性名完全一致,该列才能映射成功。

如果查询的列名和映射的pojo属性名全部不一致,则不会创建pojo对象;

如果查询的列名和映射的pojo属性名有一个一致,就会创建pojo对象。

2、输出简单类型

 当输出结果只有一列时,可以使用ResultType指定简单类型作为输出结果类型。

第一步:Mapper映射文件

<!-- 综合查询用户信息总数,需要传入查询条件复杂,比如(用户信息、订单信息、商品信息) -->

<select id="findUsersCount" parameterType="UserQueryVO"

      resultType="int">

      SELECT count(1) FROM USER WHERE sex =#{userExt.sex} AND username LIKE'%${userExt.username}%'

</select>

第二步:Mapper接口

//综合查询用户信息总数。学习:resultType输出简单类型

public int findUsersCount(UserQueryVOvo);

第三步:测试代码

@Test

publicvoidtestFindUsersCount() {

    // 创建SqlSession

    SqlSession sqlSession = sqlSessionFactory.openSession();

    // 通过SqlSession,获取mapper接口的动态代理对象

    UserMapper userMapper =sqlSession.getMapper(UserMapper.class);

 

    //构造userQueryVO对象

    UserQueryVO userQueryVO = new UserQueryVO();

       

    // 构造UserExt对象

    UserExt userExt = new UserExt();

    userExt.setSex("1");

    userExt.setUsername("小明");

       

    userQueryVO.setUserExt(userExt);

 

   int count = mapper.findUsersCount(userQueryVO);

   System.out.println(count);  // 关闭SqlSession

    sqlSession.close();

}

3、输出POJO单个对象和列表

   注意:输出单个pojo对象和pojo列表(盛放pojo对象)时,mapper映射文件中的resultType的类型是一样的,mapper接口的方法返回值不同。

第一步:Mapper映射文件

<select id="findUsersByName" parameterType="java.lang.String" resultType="cn.itcast.mybatis.po.User">

        SELECT* FROM USER WHERE username LIKE '%${value}%'

</select>

第二步:Mapper接口

下面看下mapper接口的不同之处

l  输出单个pojo对象

//根据用户名称来模糊查询用户信息

public User findUsersByName(String username);

l  输出pojo列表

//根据用户名称来模糊查询用户信息列表

    public List<User>findUsersByName(String username);

 

总结:同样的mapper映射文件,返回单个对象和对象列表时,mapper接口在生成动态代理的时候,会根据返回值的类型,决定调用selectOne方法还是selectList方法。

1.2.2.2.      resultType

resultMap可以进行高级结果映射(一对一、一对多映射)。

1、使用方法

如果查询出来的列名和属性名不一致,通过定义一个resultMap将列名和pojo属性名之间作一个映射关系。

l  定义resultMap

l  使用resultMap作为statement的输出映射类型。

2、需求

把下面SQL的输出结果集进行映射

SELECT id id_,username username_,sex sex_FROM USER WHERE id = 1

3、Mapper映射文件

定义resultMap:

<!-- 定义resultMap-->

<!--

    [id]:定义resultMap的唯一标识

    [type]:定义该resultMap最终映射的pojo对象

    [id标签]:映射结果集的唯一标识列,如果是多个字段联合唯一,则定义多个id标签

    [result标签]:映射结果集的普通列

    [column]SQL查询的列名,如果列有别名,则该处填写别名

    [property]pojo对象的属性名

-->

<resultMap type="user" id="userResultMap">

    <id column="id_" property="id"/>

    <result column="username_" property="username"/>

    <result column="sex_" property="sex"/>

</resultMap>

 

定义statement:

<!-- 根据ID查询用户信息(学习resultMap -->

<select id="findUserByIdResultMap" parameterType="int" resultMap="userResultMap">

SELECT id id_,username username_,sex sex_ FROM USER WHERE id =#{id}

</select>

4、Mapper接口定义

//根据ID查询用户信息(学习resultMap

    public User findUserByIdResultMap(int id);

定义Statement使用resultMap映射结果集时,Mapper接口定义方法的返回值类型为mapper映射文件中resultMaptype类型。

5、测试代码

@Test

publicvoid findUserByIdResultMapTest() {

    // 创建SqlSession

    SqlSession sqlSession = sqlSessionFactory.openSession();

    // 通过SqlSession,获取mapper接口的动态代理对象

    UserMapper userMapper =sqlSession.getMapper(UserMapper.class);

 

    // 调用mapper对象的方法

    User user = userMapper.findUserByIdResultMap(1);

 

    System.out.println(user);

    // 关闭SqlSession

    sqlSession.close();

}

 

1.3. 动态Sql(重点)

通过Mybatis提供的各种动态标签实现动态拼接sql,使得mapper映射文件在编写SQL时更加灵活,方便。常用动态SQL标签有:if、where、foreach;

1.3.1.  If和where

Ø  If标签:作为判断入参来使用的,如果符合条件,则把if标签体内的SQL拼接上。

注意:用if进行判断是否为空时,不仅要判断null,也要判断空字符串‘’;

Ø  Where标签:会去掉条件中的第一个and符号。

1、需求

用户信息综合查询列表和用户信息综合查询总数这两个statement的定义使用动态SQL。

2、映射文件

<!-- 综合查询用户信息,需要传入查询条件复杂,比如(用户信息、订单信息、商品信息) -->

<select id="findUsersByQueryVO" parameterType="cn.itcast.mybatis.po.QueryUserVO"

      resultType="User">

      SELECT * FROM USER

   <where>

      <if test="userExt !=null">

         <if test="userExt.sex != null and userExt.sex != ''">

            AND sex = #{userExt.sex}

         </if>

         <if test="userExt.username != null and userExt.username !=''">

            AND username LIKE'%${userExt.username}%'

         </if>

      </if>

   </where>

</select>

  

<!-- 综合查询用户信息总数,需要传入查询条件复杂,比如(用户信息、订单信息、商品信息) -->

<select id="findUsersCount" parameterType="QueryUserVO"

      resultType="int">

   SELECTcount(1) FROM USER

   <where>

      <if test="userExt !=null">

         <if test="userExt.sex != null and userExt.sex != ''">

            AND sex = #{userExt.sex}

         </if>

         <if test="userExt.username != null and userExt.username !=''">

            AND username LIKE'%${userExt.username}%'

         </if>

      </if>

   </where>

</select>

3、Mapper接口

//通过包装类来进行复杂的用户信息综合查询

public List<UserExt>findUserList(UserQueryVO userQueryVO);

//综合查询用户总数

public int findUsersCount(UserQueryVOuserQueryVO);

4、测试代码:

不传用户名:

输出的SQL如下(也不包含用户名):

通过测试可以得知,打印出的SQL语句确实会随着条件的满足情况而不一样。

 

1.3.2.  Sql片段

Mybatis提供了SQL片段的功能,可以提高SQL的可重用性。

1、定义sql片段

使用sql标签来定义一个SQL片段:

<!-- 定义SQL片段 -->

<!--

    [sql标签]:定义一个SQL片段

    [id]SQL片段的唯一标识

    建议:

        1SQL片段中的内容最好是以单表来定义

        2、如果是查询字段,则不要写上SELECT

        3、如果是条件语句,则不要写上WHERE

 -->

<sql id="select_user_where">

    <if test="userExt != null">

      <if test="userExt.sex !=null and userExt.sex != ''">

         ANDsex = #{userExt.sex}

      </if>

      <if test="userExt.username!= null and userExt.username != ''">

         AND usernameLIKE '%${userExt.username}%'

      </if>

   </if>

</sql>

2、引用sql片段

使用<include refid=’’ /> 来引用SQL片段:

<!-- 根据用户id来查询用户信息(使用SQL片段) -->

<!--

    [include标签]:引用已经定义好的SQL片段

    [refid]:引用的SQL片段id

-->

<select id="findUserList" parameterType="userQueryVO" resultType="userExt">

 

    SELECT * FROM USER

<where>

      <include refid="select_user_where"/>

   </where>

</select>

<!-- 综合查询用户信息总数,需要传入查询条件复杂,比如(用户信息、订单信息、商品信息) -->

<select id="findUsersCount" parameterType="QueryUserVO"

      resultType="int">

   SELECTcount(1) FROM USER

   <where>

      <include refid="select_user_where"/>

   </where>

</select>

1.3.3.  Foreach

向sql传递数组或List时,mybatis使用foreach解析数组里的参数并拼接到SQL中。

1.3.3.1.      传递pojo对象的List集合

1、需求

在用户查询列表和查询总数的statement中增加多个id输入查询。

2、Sql

SELECT * FROM user WHERE id IN (1,10,16)

3、定义pojo中的List属性

4、映射文件

<!-- [foreach标签]:表示一个foreach循环 -->

<!-- [collection]:集合参数的名称,如果是直接传入集合参数,则该处的参数名称只能填写[list] -->

<!-- [item]:每次遍历出来的对象 -->

<!-- [open]:开始遍历时拼接的串 -->

<!-- [close]:结束遍历时拼接的串 -->

<!-- [separator]:遍历出的每个对象之间需要拼接的字符 -->

<if test="idList != null and idList.size > 0">

<foreach collection="idList" item="id"open="AND id IN (" close=")" separator=",">

        #{id}

</foreach>

</if>

5、Mapper接口

//根据用户ID的集合查询用户列表(学习foreach标签之通过POJO对象传ID集合)

public List<UserExt> findUserList(UserQueryVO vo);

6、测试代码

@Test

publicvoid testFindUserList() {

    // 创建SqlSession

    SqlSession sqlSession = sqlSessionFactory.openSession();

    // 通过SqlSession,获取mapper接口的动态代理对象

    UserMapper mapper =sqlSession.getMapper(UserMapper.class);

 

    // 构造QueryUserVO对象

    QueryUserVO vo = new QueryUserVO();

    // UserExt ext = new UserExt();

    // ext.setUsername("小明");

    // ext.setSex("1");

    // vo.setUserExt(ext);

 

    // 创建用户ID集合,然后设置到QueryUserVO对象中

    List<Integer> idList = newArrayList<Integer>();

    idList.add(1);

    idList.add(10);

    idList.add(16);

    vo.setIdList(idList);

 

    // 调用mapper代理对象的方法

    List<UserExt> list =mapper.findUserList(vo);

    System.out.println(list);

    // 关闭SqlSession

    sqlSession.close();

}

1.3.3.2.      直接传递List集合

1、需求

根据用户ID的集合查询用户列表

2、Sql

SELECT * FROM user WHERE id IN (1,10,16)

 

3、映射文件

<!-- 根据用户ID的集合查询用户列表(学习foreach标签之直接传ID集合) -->

<!--

    [foreach标签]:表示一个foreach循环

    [collection]:集合参数的名称,如果是直接传入集合参数,则该处的参数名称只能填写[list]

    [item]:定义遍历集合之后的参数名称

    [open]:开始遍历之前需要拼接的SQL

    [close]:结束遍历之后需要拼接的SQL

    [separator]:遍历出的每个对象之间需要拼接的字符

 -->

<select id="findUsersByIdList" parameterType="java.util.List"resultType="user">

    SELECT * FROM USER

    <where>

        <if test="list[少东家1]  != null and list.size > 0">

            <foreach collection="list" item="id"open="AND id IN (" close=")" separator=",">

                #{id}

            </foreach>

        </if>

    </where>

</select>

4、Mapper接口

//根据用户ID的集合查询用户列表(学习foreach标签之直接传ID集合)

public List<User>findUsersByIdList (List<Integer> idList);

5、测试代码

@Test

publicvoid findUsersByIdListTest() {

    // 创建SqlSession

    SqlSession sqlSession = sqlSessionFactory.openSession();

    // 通过SqlSession,获取mapper接口的动态代理对象

    UserMapper userMapper =sqlSession.getMapper(UserMapper.class);

 

    // 构造List<Integer>集合

    List<Integer> idList = new ArrayList<Integer>();

    idList.add(1);

    idList.add(10);

idList.add(16);

 

    // 调用mapper对象的方法

    List<User> list =userMapper.findUsersByIdList (idList);

    System.out.println(list);

    // 关闭SqlSession

    sqlSession.close();

}

1.4. Mybatis和hibernate的区别:

Mybatis技术特点:

1、通过直接编写SQL语句,可以直接对SQL进行性能的优化;

2、学习门槛低,学习成本低。只要有SQL基础,就可以学习mybatis,而且很容易上手;

3、由于直接编写SQL语句,所以灵活多变,代码维护性更好。

4、不能支持数据库无关性,即数据库发生变更,要写多套代码进行支持,移植性不好。

5、需要编写结果映射。

Hibernate技术特点:

1、标准的orm框架,程序员不需要编写SQL语句。

2、具有良好的数据库无关性,即数据库发生变化的话,代码无需再次编写。

3、学习门槛高,需要对数据关系模型有良好的基础,而且在设置OR映射的时候,需要考虑好性能和对象模型的权衡。

4、程序员不能自主的去进行SQL性能优化。

 

Mybatis应用场景:

       需求多变的互联网项目,例如电商项目。

Hibernate应用场景:

       需求明确、业务固定的项目,例如OA项目、ERP项目等。


如果是直接传入集合参数,则该处的参数名称只能填写[list]

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/u013110682/article/details/80000714

智能推荐

240320俄罗斯方块java,JAVA游戏编程之三----j2me 手机游戏入门开发--俄罗斯方块_2-程序员宅基地

文章浏览阅读202次。packagecode;//importjava.awt.*;//importjava.awt.Canvas;//importjava.awt.event.*;//importjavax.swing.*;importjava.util.Random;importjavax.microedition.lcdui.*;//写界面所需要的包/***//***俄罗斯方块*高雷*2007年1..._240×320java游戏

在线电影院售票平台(源码+开题报告)-程序员宅基地

文章浏览阅读779次,点赞14次,收藏19次。然后,实现系统的数据管理和服务功能,包括用户的注册与登录、电影的分类与展示、电影信息的查询与推荐、座位的选择与预订、在线支付与电子票生成等。此外,随着在线视频平台的兴起,越来越多的人选择在线观看电影,这对传统电影院产生了巨大的冲击。研究意义: 开发在线电影院售票平台对于提升用户的观影体验、优化电影院的运营效率、促进电影产业的发展具有重要的意义。该系统旨在通过技术手段解决传统电影院售票中的问题,提供一个集成化的电影信息展示、座位选择、在线支付和用户评价平台,同时也为电影院和电影制作方提供有效的工具。

程序员熬夜写代码,用C/C++打造一个安全的即时聊天系统!_基于c++的即时聊天系统设计-程序员宅基地

文章浏览阅读509次。保护我们剩下的人的通话信息安全,使用TOX可以让你在和家人,朋友,爱人交流时保护你的隐私不受政府无孔不入的的偷窥.关于TOX:其他牛逼的软件因为一些细化服务问你要钱的时候, TOX分文不取 . 你用了TOX, 想干嘛就干嘛.网友评论:项目源码展示:源码测试效果:最后,如果你学C/C++编程有什么不懂的,可以来问问我哦,或许我能够..._基于c++的即时聊天系统设计

linux Java服务swap分区被占用内存泄露问题故障及解决方法_linux swap占用很高-程序员宅基地

文章浏览阅读584次。鱼弦:CSDN内容合伙人、CSDN新星导师、全栈领域创作新星创作者 、51CTO(Top红人+专家博主) 、github开源爱好者(go-zero源码二次开发、游戏后端架构 https://github.com/Peakchen)当Java服务在Linux系统中运行时,可能会出现swap分区被占用的内存泄露问题,导致系统性能下降或者崩溃。下面是该问题的故障及解决方法、底层结构、架构图、工作原理、使用场景详解和实际应用方式、原理详细描述、相关命令使用示例以及文献材料链接。_linux swap占用很高

word中利用宏替换标点标点全角与半角-程序员宅基地

文章浏览阅读662次。Alt+F11,然后插入-模块:复制下面代码到编辑窗口:Sub 半角标点符号转换为全角标点符号()'中英互译文档中将中文段落中的英文标点符号替换为中文标点符号 Dim i As Paragraph, ChineseInterpunction() As Variant, EnglishInterpunction() As Variant Dim MyRange..._替换半角宏

Android WebView使用总结_android webview真正加载完成-程序员宅基地

文章浏览阅读2.8k次。#.简介: WebView是Android提供的用来展示展示web页面的View,内部使用webkit浏览器引擎(一个轻量级的浏览器引擎),除了展示Web页面外,还可与Web页面内的JS脚本交互调用。WebView内部的WebSetting对象负责管理WebView的参数配置; WebViewClient负责处理WebView的各种请求和通知事件,在对应事件发生时会执行WebViewClient的对应回调; ChromeWebviewClient辅助Webview处理与JS一些交互......_android webview真正加载完成

随便推点

bitcoin 调试环境搭建-程序员宅基地

文章浏览阅读1.6k次。_bitcoin 调试环境搭建

曲线生成 | 图解B样条曲线生成原理(基本概念与节点生成算法)-程序员宅基地

文章浏览阅读4.3k次,点赞93次,收藏94次。为了解决贝塞尔曲线无法局部修正、控制性减弱、曲线次数过高、不易拼接的缺陷,引入B样条曲线(B-Spline)。本文介绍B样条曲线的基本概念:节点向量、支撑性、次数阶数、加权性质、节点生成算法等,为后续曲线计算打下基础。_样条曲线生成

CDH安装宝典之ClouderaManager_/opt/cloudera/cm-agent/service/mgmt/mgmt.sh: line -程序员宅基地

文章浏览阅读902次。配置本地repo库下载我的阿里云盘文件文件放置#创建目录mkdir -p /opt/cloudera/parcel-repo/mkdir -p /opt/cloudera/cm/yum install createrepoCDH 6.2.0 的三个文件放到/opt/cloudera/parcel-repo/中,并且注意把sha256后缀的文件名修改为sha#执行createrepo命令生成rpm元数据 最终/opt/cloudera/parcel-repo/会多一个repodata目录_/opt/cloudera/cm-agent/service/mgmt/mgmt.sh: line 76: /usr/java/jdk1.8.0_181

uni.canvasToTempFilePath在app正常,微信小程序报错: fail canvas is empty-程序员宅基地

文章浏览阅读943次,点赞2次,收藏2次。uni.canvasToTempFilePath_uni.canvastotempfilepath

SDRAM笔记_sdram 干扰-程序员宅基地

文章浏览阅读3.1k次。SRAM :静态RAM,不用刷新,速度可以非常快,像CPU内部的cache,都是静态RAM,缺点是一个内存单元需要的晶体管数量多,因而价格昂贵,容量不大。DRAM:动态RAM,需要刷新,容量大。SDRAM:同步动态RAM,需要刷新,速度较快,容量大。DDR SDRAM:双通道同步动态RAM,需要刷新,速度快,容量大。........................_sdram 干扰

Excel转SQL语句_excel数据怎么生成sql语句-程序员宅基地

文章浏览阅读7.3k次。假设表格有A、B、C、D四列数据,希望导入到你的数据库中表格table,对应的字段分别是col1、col2、col3、col4。_excel数据怎么生成sql语句

推荐文章

热门文章

相关标签