- 36. MyBatis如何支持多数据库操作?如何配置不同的数据源?
这孩子叫逆
Mybatis笔记mybatis数据库
在许多企业级应用中,可能需要访问多个数据库。MyBatis可以通过配置多个数据源和动态切换数据源来支持多数据库操作。下面介绍如何在MyBatis中配置和使用多个数据源。1.多数据源的基本配置1.1配置多个数据源要支持多个数据源,首先需要在Spring或SpringBoot中配置不同的数据源。假设我们要连接两个数据库db1和db2,可以通过以下步骤进行配置。SpringBoot示例:applicat
- 一文让你彻底弄懂Redux的基本原理以及其如何在React中使用!
tabzzz
react.jsjavascriptecmascript
文章目录什么是Redux?它有什么用Redux基本原理Redux在React中具体使用的方法ReduxToolkit(RTK)createSlice函数参数返回值示例configureStore函数参数返回值示例React-ReduxProvider组件示例React组件使用store中的数据useSelector钩子函数示例connect组件mapStateToPropsmapDispatchT
- 通过DBeaver连接Phoenix操作hbase
不想做咸鱼的王富贵
通过DBeaver连接Phoenix操作hbase前言本文介绍常用一种通用数据库工具Dbeaver,DBeaver可通过JDBC连接到数据库,可以支持几乎所有的数据库产品,包括:MySQL、PostgreSQL、MariaDB、SQLite、Oracle、Db2、SQLServer、Sybase、MSAccess、Teradata、Firebird、Derby等等。商业版本更是可以支持各种NoSQ
- SvelteKit Flash Message 使用教程
裴剑苹
SvelteKitFlashMessage使用教程sveltekit-flash-messageSendtemporarydataafterredirect,usuallyfromendpoints.WorkswithbothSSRandclient.项目地址:https://gitcode.com/gh_mirrors/sv/sveltekit-flash-message1.项目介绍svelte
- Explore-Flutter-FireStore: 使用Flutter结合Firebase Firestore的实战指南
戴洵珠Gerald
Explore-Flutter-FireStore:使用Flutter结合FirebaseFirestore的实战指南Explore-Flutter-FireStoreThisisaFlutterAppwithFirebase'sCloudFireStoreDatabaseandGoogleMap.ThisapprepresentsthatBeautifulUIcanbeimplementedwi
- Firestore 与 Android 架构组件实战示例
张栋涓Kerwin
Firestore与Android架构组件实战示例firestore-android-arch-componentsFirestoresamplewithAndroidarchitecturecomponent.项目地址:https://gitcode.com/gh_mirrors/fi/firestore-android-arch-components项目介绍该项目是基于Google的Fireb
- gdb常用命令
过好每一天的女胖子
linuxgdblinuxgdb
文章目录1、GDB2、常用命令gdb可执行文件名run(r)/start运行程序break/bclear/deletedisable/enabledisplayjumpwhatisinfothreadbacktrace/btnext(n)/nextistep(s)/stepifinishuntilcallsetprint/plistwatch/awatch/rwatchcatch/tcatchxc
- ASP.NET中Response.Redirect的用法(详细)
微微的猪食小窝
asp.net服务器java
一、Response.Redirect是重定向到新的url。例如:if(!IsPostBack){if(Session["UserId"]==null||Session["UserId"].ToString()==""){Response.Redirect(Oper.GetSysUrl()+"/Default.aspx");//转到主页}******//其他实现代码}二、若想传递参数,只要在url
- 07_React 路由
qiao若huan喜
React全家桶react.js前端前端框架
React路由(5.x版本)一、相关理解1、SPA的理解2、路由的理解2.1什么是路由?2.2路由分类2.2.1后端路由2.2.2前端路由3、react-router-dom(Web开发使用)的理解二、react-router-dom相关API1、内置组件1.1BrowserRouter1.2HashRouter1.3Route1.4Redirect1.5Link1.6NavLink1.7Swit
- HTML提交表单给python
一壶浊酒..
前端开发htmlpython前端
python代码fromflaskimportFlask,request,render_template,redirect,url_forapp=Flask(__name__)@app.route('/')defform():#渲染表单页面returnrender_template('./index.html')@app.route('/submit_form',methods=['POST'])
- VCS命令行CTRL+C后dump完整的fsdb波形
sunvally
数字验证verdiuclidump
UCLI命令行CTRL+C后dump完整的fsdb波形:1.ucli%fsdbDumpFinish2.ucli%fsdbDumpvars0"harness""+mda""+struct"如果仿真过程中直接CTRL+C会调到UCLI接口,此时如果仅是将FSDB波形拷贝到某个地方的话,verdi无法打开该波形(verdi-ssf$(tc)_$(seed).fsdb)。另外也无法用fsdb2vcd命令将
- ORACLE Virtual Private Database(VPD)
rfb0204421
MOACoracledatabasesecurity数据库sqlserversession
行记录级访问控制(ROW-RULEcontrol)问题的提出和意义?企业的应用系统都离不开数据库系统,数据库系统的权限控制是很重要的一个环节,大型数据库系统(ORACLE、DB2、SYBASE、MSSQLSERVER)都提供完善的用户管理机制,从而可以严密地控制数据库对象(表、视图、函数、存储过程、程序包等等)的访问。但是,这往往是对象级别的。随着商务需求地不断地提出,出现了对于行记录控制的要求:
- ORACLE 的Virtual Private Database的全新体验
loveyon
dboracledatabasesecurityfunction数据库sql
1、ROW-RULEcontrol(行记录级访问控制)的简单概念:行记录级访问控制问题的提出和意义?企业的应用系统都离不开数据库系统,数据库系统的权限控制是很重要的一个环节,大型数据库系统(ORACLE、DB2、SYBASE、MSSQLSERVER)都提供完善的用户管理机制,从而可以严密地控制数据库对象(表、视图、函数、存储过程、程序包等等)的访问。但是,这往往是对象级别的。随着商务需求地不断地提
- mysql中insert into select from的使用
SHENHUANJIE
数据库
mysql中insertintoselectfrom的使用如何在MySQL从多个表中组合字段然后插入到一个新表中,通过一条sql语句实现。具体情形是:有三张表a、b、c,现在需要从表b和表c中分别查几个字段的值插入到表a中对应的字段。对于这种情况,我们可以使用如下的语句来实现:INSERTINTOdb1_name(field1,field2)SELECTfield1,field2FROMdb2_n
- Install MariaDB
weixin_33998125
数据库运维
1.yuminstallmariadb-servermariadb2.systemctlenablemariadb;systemctlstartmariadb3.mysql_secure_installation4.mysql-uroot-pmysql-e"SELECTUser,HostFROMuser"5.mysql-uroot-p6.CREATEDATABASEdb1CHARACTERSETu
- [makeself|shell] 使用makeself制作linux应用程序安装包
梦醒贰零壹柒
SHELL脚本shell
打包工具makeself安装sudoaptinstallmakeself目录结构.├──bin│└──install.sh├──resources│└──应用程序压缩包└──package.sh安装脚本install.sh#!/bin/bash_backup(){echo"备份数据"}_restore(){echo"还原数据"}_install(){#备份数据_backup#获取当前目录curre
- 基于 AT 固件测试 ESP32 设备作为 WiFi AP 模式创建 TCP Server 开启 UART-to-WiFi 透传模式的指令序列
Rainbow.Cai
ATtcp/ip服务器网络协议
AT指令序列如下AT+RESTOREAT+CWMODE=2//SettheWi-FimodetoSoftAP.AT+CWSAP="ESP32_softAP","1234567890",5,3//SetsoftAPAT+CIPMUX=1//EnablemultipleconnectionsforTCPServerAT+CIPSERVERMAXCONN=1//Setthemaximumnumberof
- 小程序中用于跳转页面的5个api是什么?区别是什么
茶卡盐佑星_
小程序前端
小程序中用于跳转页面的5个主要API分别是wx.navigateTo、wx.redirectTo、wx.reLaunch、wx.switchTab和wx.navigateBack。这些API各自具有不同的功能和特点,适用于不同的页面跳转场景。以下是它们的详细介绍及区别:1.wx.navigateTo功能:保留当前页面,跳转到应用内的某个页面。使用wx.navigateBack可以返回到原页面。特性
- 2.8.6Flask --5 Flask的cookie与session
寒暄_HX
Flask目录:https://www.jianshu.com/p/9b5e30320849关于什么是cookie,什么是session不在赘述。这里是一个登录注销实例:fromflaskimportFlask,url_for,request,render_template,redirect,session,make_responseapp=Flask(__name__)app.config['T
- alias和redirect的区别
qq_41068783
1redirect:重定向{path:'/home',name:'home',component:()=>import('@/components/a.vue'),redirect:'/index'//重定向}当访问/home时,跳转后显示的url:/index显示的是重定向后的地址即index2alias:别名{path:'/home',component:Home,name:'home',al
- Hyper-v虚拟机备份与还原实现(三)
稔稔
Hyper-v备份还原Hyper-vposershellC#C
备份完还原就比较简单了;第一步dir管理端执行还原任务从数据库获取需要还原的hyperv虚拟机和host名;不做过多说明;第二步fd端通过hyperv虚拟机名和host名还原虚拟机还原主要通过一个New-VM命令,fd通过调用system(“restore.exe”)来执行还原;restore.exe源码如下:usingSystem;usingSystem.Collections.Generic;
- Sqlite3数据库的学习
smile202066
数据库
数据存储方式1、内存存数据:当程序运行结束,掉电,数据丢失。(数组、链表、变量等)2、硬盘存数据:程序运行结束,掉电,数据不丢失(1)文件:对数据管理(增删改查)效率低.(2)数据库:专业存储数据,可存大量数据。对数据管理效率高,使用方便。常用数据库:1.关系型数据库:将复杂的数据结构简化为二维表格形式大型:Oracle、DB2中型:MySql、SQLServer小型:Sqlite2.非关系型数据
- 微信小程序 跳转
tanzongbiao
微信小程序小程序
普通跳转wx.navigateTo({url:'/pages/xxx/xxx'})返回wx.navigateBack({})wx.navigateBack({delta:0})关闭当前页并跳转wx.redirectTo({url:'pages/xxx/xxx'})切换主菜单wx.switchTab({ url: '../store/index'})小程序跳转wx.navigateToMiniPro
- 支付宝生活号获取用户授权
Strawberry96
支付宝生活号前端
为了下次不用再去看一遍官方文档,简单的做一下笔记。想了解更多的细节,请移步支付宝官方文档1、用户授权,拼接的url,如下:获取用户信息的授权scope=auth_user:https://openauth.alipay.com/oauth2/publicAppAuthorize.htm?app_id=APPID&scope=auth_user&redirect_uri=ENCODED_URL?st
- 关于 router-view-slot
今晚也失眠
前端javascript开发语言
关于router-view-slotApp.vue配置动态路由importlayoutfrom"@/layout/index.vue";constrouter=createRouter({history:createWebHistory(import.meta.env.BASE_URL),routes:[{path:"/",name:"layout",redirect:"/dashboard",c
- Clickhouse篇之数据的备份与恢复
听说唐僧不吃肉
Clickhouseclickhouse数据库
Clickhouse数据的备份与恢复要备份ClickHouse数据库中的数据表,你可以使用ClickHouse提供的BACKUP和RESTORE功能,或者通过手动备份文件系统中的数据目录来实现。以下是两种常用的方法:方法一:使用BACKUP和RESTORE功能从ClickHouse21.8版本开始,支持BACKUP和RESTORE命令。以下是备份和恢复的步骤:1.备份数据库备份整个数据库BACKU
- 20240824给飞凌OK3588-C的核心板刷Ubuntu22.04并连接adb
南棱笑笑生
杂质c语言adb开发语言
20240824给飞凌OK3588-C的核心板刷Ubuntu22.04并连接adb2024/8/2415:56缘起,由于我司对面积有极度的追求,所以将飞凌OK3588-C开发板使用的【9线+】type-C接口(USB3.1?)降级为4线的USB2.0。【microUSB/MINIUSB。】先决条件:1、电脑有网络。因为需要在线安装软件。当然你有能力的话,貌似可以把需要安装的软件直接打包到Ubunt
- HttpResponse响应、render 响应、redirect 响应、JsonResponse 响应
Yietong309
Djangodjangopython后端
目录HttpResponse介绍常用属性content:返回的内容编辑content_type:返回给数据的MIME类型status_code:返回的HTTP响应状态码render返回网页给网页传值1.指名道姓方式传值2.使用locals()将函数内部所有的变量名都传给网页,包括requestredirect重定向传递一个具体的ORM对象(了解即可)传递一个视图的名称跳转至其他网址写全地址名Jso
- Django必会三剑客(render、HttpResponse、redirect)
泛滥的青春里谁是谁的谁ゝ
pythonDjangodjangorenderHttpResponseredirectdjango三剑客
Django必会三剑客(render、HttpResponse、redirect)导包路径fromdjango.shortcutsimportrender,HttpResponse,redirectHttpResponse用于返回字符串fromdjango.shortcutsimportrender,HttpResponse,redirectdeftest(request):returnHttpR
- Django模板语法及render,HttpResponse,redirect
柒拾霜染
djangopython后端
建立path,建立viewdefreview(request):importtime'''模板语法'''num1=22num2=11strl='123'array=['a','b','c']dictl={'h':'head','b':'body','c':'content'}returnrender(request,'grammar.html',{'n1':num1,'n2':num2,'n3':
- jQuery 跨域访问的三种方式 No 'Access-Control-Allow-Origin' header is present on the reque
qiaolevip
每天进步一点点学习永无止境跨域众观千象
XMLHttpRequest cannot load http://v.xxx.com. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:63342' is therefore not allowed access. test.html:1
- mysql 分区查询优化
annan211
java分区优化mysql
分区查询优化
引入分区可以给查询带来一定的优势,但同时也会引入一些bug.
分区最大的优点就是优化器可以根据分区函数来过滤掉一些分区,通过分区过滤可以让查询扫描更少的数据。
所以,对于访问分区表来说,很重要的一点是要在where 条件中带入分区,让优化器过滤掉无需访问的分区。
可以通过查看explain执行计划,是否携带 partitions
- MYSQL存储过程中使用游标
chicony
Mysql存储过程
DELIMITER $$
DROP PROCEDURE IF EXISTS getUserInfo $$
CREATE PROCEDURE getUserInfo(in date_day datetime)-- -- 实例-- 存储过程名为:getUserInfo-- 参数为:date_day日期格式:2008-03-08-- BEGINdecla
- mysql 和 sqlite 区别
Array_06
sqlite
转载:
http://www.cnblogs.com/ygm900/p/3460663.html
mysql 和 sqlite 区别
SQLITE是单机数据库。功能简约,小型化,追求最大磁盘效率
MYSQL是完善的服务器数据库。功能全面,综合化,追求最大并发效率
MYSQL、Sybase、Oracle等这些都是试用于服务器数据量大功能多需要安装,例如网站访问量比较大的。而sq
- pinyin4j使用
oloz
pinyin4j
首先需要pinyin4j的jar包支持;jar包已上传至附件内
方法一:把汉字转换为拼音;例如:编程转换后则为biancheng
/**
* 将汉字转换为全拼
* @param src 你的需要转换的汉字
* @param isUPPERCASE 是否转换为大写的拼音; true:转换为大写;fal
- 微博发送私信
随意而生
微博
在前面文章中说了如和获取登陆时候所需要的cookie,现在只要拿到最后登陆所需要的cookie,然后抓包分析一下微博私信发送界面
http://weibo.com/message/history?uid=****&name=****
可以发现其发送提交的Post请求和其中的数据,
让后用程序模拟发送POST请求中的数据,带着cookie发送到私信的接入口,就可以实现发私信的功能了。
- jsp
香水浓
jsp
JSP初始化
容器载入JSP文件后,它会在为请求提供任何服务前调用jspInit()方法。如果您需要执行自定义的JSP初始化任务,复写jspInit()方法就行了
JSP执行
这一阶段描述了JSP生命周期中一切与请求相关的交互行为,直到被销毁。
当JSP网页完成初始化后
- 在 Windows 上安装 SVN Subversion 服务端
AdyZhang
SVN
在 Windows 上安装 SVN Subversion 服务端2009-09-16高宏伟哈尔滨市道里区通达街291号
最佳阅读效果请访问原地址:http://blog.donews.com/dukejoe/archive/2009/09/16/1560917.aspx
现在的Subversion已经足够稳定,而且已经进入了它的黄金时段。我们看到大量的项目都在使
- android开发中如何使用 alertDialog从listView中删除数据?
aijuans
android
我现在使用listView展示了很多的配置信息,我现在想在点击其中一条的时候填出 alertDialog,点击确认后就删除该条数据,( ArrayAdapter ,ArrayList,listView 全部删除),我知道在 下面的onItemLongClick 方法中 参数 arg2 是选中的序号,但是我不知道如何继续处理下去 1 2 3
- jdk-6u26-linux-x64.bin 安装
baalwolf
linux
1.上传安装文件(jdk-6u26-linux-x64.bin)
2.修改权限
[root@localhost ~]# ls -l /usr/local/jdk-6u26-linux-x64.bin
3.执行安装文件
[root@localhost ~]# cd /usr/local
[root@localhost local]# ./jdk-6u26-linux-x64.bin&nbs
- MongoDB经典面试题集锦
BigBird2012
mongodb
1.什么是NoSQL数据库?NoSQL和RDBMS有什么区别?在哪些情况下使用和不使用NoSQL数据库?
NoSQL是非关系型数据库,NoSQL = Not Only SQL。
关系型数据库采用的结构化的数据,NoSQL采用的是键值对的方式存储数据。
在处理非结构化/半结构化的大数据时;在水平方向上进行扩展时;随时应对动态增加的数据项时可以优先考虑使用NoSQL数据库。
在考虑数据库的成熟
- JavaScript异步编程Promise模式的6个特性
bijian1013
JavaScriptPromise
Promise是一个非常有价值的构造器,能够帮助你避免使用镶套匿名方法,而使用更具有可读性的方式组装异步代码。这里我们将介绍6个最简单的特性。
在我们开始正式介绍之前,我们想看看Javascript Promise的样子:
var p = new Promise(function(r
- [Zookeeper学习笔记之八]Zookeeper源代码分析之Zookeeper.ZKWatchManager
bit1129
zookeeper
ClientWatchManager接口
//接口的唯一方法materialize用于确定那些Watcher需要被通知
//确定Watcher需要三方面的因素1.事件状态 2.事件类型 3.znode的path
public interface ClientWatchManager {
/**
* Return a set of watchers that should
- 【Scala十五】Scala核心九:隐式转换之二
bit1129
scala
隐式转换存在的必要性,
在Java Swing中,按钮点击事件的处理,转换为Scala的的写法如下:
val button = new JButton
button.addActionListener(
new ActionListener {
def actionPerformed(event: ActionEvent) {
- Android JSON数据的解析与封装小Demo
ronin47
转自:http://www.open-open.com/lib/view/open1420529336406.html
package com.example.jsondemo;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
impor
- [设计]字体创意设计方法谈
brotherlamp
UIui自学ui视频ui教程ui资料
从古至今,文字在我们的生活中是必不可少的事物,我们不能想象没有文字的世界将会是怎样。在平面设计中,UI设计师在文字上所花的心思和功夫最多,因为文字能直观地表达UI设计师所的意念。在文字上的创造设计,直接反映出平面作品的主题。
如设计一幅戴尔笔记本电脑的广告海报,假设海报上没有出现“戴尔”两个文字,即使放上所有戴尔笔记本电脑的图片都不能让人们得知这些电脑是什么品牌。只要写上“戴尔笔
- 单调队列-用一个长度为k的窗在整数数列上移动,求窗里面所包含的数的最大值
bylijinnan
java算法面试题
import java.util.LinkedList;
/*
单调队列 滑动窗口
单调队列是这样的一个队列:队列里面的元素是有序的,是递增或者递减
题目:给定一个长度为N的整数数列a(i),i=0,1,...,N-1和窗长度k.
要求:f(i) = max{a(i-k+1),a(i-k+2),..., a(i)},i = 0,1,...,N-1
问题的另一种描述就
- struts2处理一个form多个submit
chiangfai
struts2
web应用中,为完成不同工作,一个jsp的form标签可能有多个submit。如下代码:
<s:form action="submit" method="post" namespace="/my">
<s:textfield name="msg" label="叙述:">
- shell查找上个月,陷阱及野路子
chenchao051
shell
date -d "-1 month" +%F
以上这段代码,假如在2012/10/31执行,结果并不会出现你预计的9月份,而是会出现八月份,原因是10月份有31天,9月份30天,所以-1 month在10月份看来要减去31天,所以直接到了8月31日这天,这不靠谱。
野路子解决:假设当天日期大于15号
- mysql导出数据中文乱码问题
daizj
mysql中文乱码导数据
解决mysql导入导出数据乱码问题方法:
1、进入mysql,通过如下命令查看数据库编码方式:
mysql> show variables like 'character_set_%';
+--------------------------+----------------------------------------+
| Variable_name&nbs
- SAE部署Smarty出现:Uncaught exception 'SmartyException' with message 'unable to write
dcj3sjt126com
PHPsmartysae
对于SAE出现的问题:Uncaught exception 'SmartyException' with message 'unable to write file...。
官方给出了详细的FAQ:http://sae.sina.com.cn/?m=faqs&catId=11#show_213
解决方案为:
01
$path
- 《教父》系列台词
dcj3sjt126com
Your love is also your weak point.
你的所爱同时也是你的弱点。
If anything in this life is certain, if history has taught us anything, it is
that you can kill anyone.
不顾家的人永远不可能成为一个真正的男人。 &
- mongodb安装与使用
dyy_gusi
mongo
一.MongoDB安装和启动,widndows和linux基本相同
1.下载数据库,
linux:mongodb-linux-x86_64-ubuntu1404-3.0.3.tgz
2.解压文件,并且放置到合适的位置
tar -vxf mongodb-linux-x86_64-ubun
- Git排除目录
geeksun
git
在Git的版本控制中,可能有些文件是不需要加入控制的,那我们在提交代码时就需要忽略这些文件,下面讲讲应该怎么给Git配置一些忽略规则。
有三种方法可以忽略掉这些文件,这三种方法都能达到目的,只不过适用情景不一样。
1. 针对单一工程排除文件
这种方式会让这个工程的所有修改者在克隆代码的同时,也能克隆到过滤规则,而不用自己再写一份,这就能保证所有修改者应用的都是同一
- Ubuntu 创建开机自启动脚本的方法
hongtoushizi
ubuntu
转载自: http://rongjih.blog.163.com/blog/static/33574461201111504843245/
Ubuntu 创建开机自启动脚本的步骤如下:
1) 将你的启动脚本复制到 /etc/init.d目录下 以下假设你的脚本文件名为 test。
2) 设置脚本文件的权限 $ sudo chmod 755
- 第八章 流量复制/AB测试/协程
jinnianshilongnian
nginxluacoroutine
流量复制
在实际开发中经常涉及到项目的升级,而该升级不能简单的上线就完事了,需要验证该升级是否兼容老的上线,因此可能需要并行运行两个项目一段时间进行数据比对和校验,待没问题后再进行上线。这其实就需要进行流量复制,把流量复制到其他服务器上,一种方式是使用如tcpcopy引流;另外我们还可以使用nginx的HttpLuaModule模块中的ngx.location.capture_multi进行并发
- 电商系统商品表设计
lkl
DROP TABLE IF EXISTS `category`; -- 类目表
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `category` (
`id` int(11) NOT NUL
- 修改phpMyAdmin导入SQL文件的大小限制
pda158
sqlmysql
用phpMyAdmin导入mysql数据库时,我的10M的
数据库不能导入,提示mysql数据库最大只能导入2M。
phpMyAdmin数据库导入出错: You probably tried to upload too large file. Please refer to documentation for ways to workaround this limit.
- Tomcat性能调优方案
Sobfist
apachejvmtomcat应用服务器
一、操作系统调优
对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,CPU的处理能力越强,系统运行速度越快。。
【适用场景】 任何项目。
二、Java虚拟机调优
应该选择SUN的JVM,在满足项目需要的前提下,尽量选用版本较高的JVM,一般来说高版本产品在速度和效率上比低版本会有改进。
J
- SQLServer学习笔记
vipbooks
数据结构xml
1、create database school 创建数据库school
2、drop database school 删除数据库school
3、use school 连接到school数据库,使其成为当前数据库
4、create table class(classID int primary key identity not null)
创建一个名为class的表,其有一