Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
S
services
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
tencent
services
Commits
d14cc342
Commit
d14cc342
authored
Sep 25, 2018
by
xmy
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
http://139.199.22.180/tencent/services
parents
55e10d24
b1ba4950
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
72 additions
and
17 deletions
+72
-17
src/Common/Entity/Split.php
+36
-17
src/Common/Entity/User.php
+11
-0
src/Common/Enum/TestEnum.php
+15
-0
src/Store/Lib/StoreInterface.php
+10
-0
No files found.
src/Common/Entity/Split.php
View file @
d14cc342
...
@@ -8,6 +8,9 @@
...
@@ -8,6 +8,9 @@
namespace
Hdll\Services\Common\Entity
;
namespace
Hdll\Services\Common\Entity
;
use
Hdll\Services\Common\Bean\Collector\SplitCollector
;
use
Hdll\Services\Common\Bean\Collector\SplitCollector
;
use
Hdll\Services\Common\Enum\TestEnum
;
use
Hdll\Services\Common\Exception\CommonException
;
use
Swoft\App
;
use
Swoft\Core\RequestContext
;
use
Swoft\Core\RequestContext
;
use
Swoft\Db\Bean\Collector\EntityCollector
;
use
Swoft\Db\Bean\Collector\EntityCollector
;
use
Swoft\Db\QueryBuilder
;
use
Swoft\Db\QueryBuilder
;
...
@@ -22,32 +25,36 @@ class Split
...
@@ -22,32 +25,36 @@ class Split
$map
=
array_flip
(
$collector
[
'map'
]);
$map
=
array_flip
(
$collector
[
'map'
]);
}
}
//如果是实体且为分表实体
if
(
!
self
::
isTesting
()
)
{
if
(
strpos
(
$tableName
,
'\\'
)
!==
false
&&
isset
(
$collector
[
$tableName
]))
{
//如果是实体且为分表实体
$className
=
$tableName
;
if
(
strpos
(
$tableName
,
'\\'
)
!==
false
&&
isset
(
$collector
[
$tableName
]))
{
$tableName
=
$collector
[
$tableName
][
'table'
];
$className
=
$tableName
;
$tableName
=
$collector
[
$tableName
][
'table'
];
$entityCollector
=
EntityCollector
::
getCollector
();
$entityCollector
=
EntityCollector
::
getCollector
();
//设置分表对应的className
//设置分表对应的className
EntityCollector
::
setCollector
(
$tableName
.
'_'
.
self
::
getDbNum
(
$className
),
$tableName
);
EntityCollector
::
setCollector
(
$tableName
.
'_'
.
self
::
getDbNum
(
$className
),
$tableName
);
//获取分表名
//获取分表名
$tableName
=
$tableName
.
'_'
.
self
::
getDbNum
(
$className
);
$tableName
=
$tableName
.
'_'
.
self
::
getDbNum
(
$className
);
//设置分表类型
//设置分表类型
$query
->
selectInstance
(
$entityCollector
[
$className
][
'instance'
]);
$query
->
selectInstance
(
$entityCollector
[
$className
][
'instance'
]);
}
elseif
(
isset
(
$map
[
$tableName
])
)
{
//非实体且分表
}
elseif
(
isset
(
$map
[
$tableName
])
)
{
//非实体且分表
$className
=
$map
[
$tableName
];
$className
=
$map
[
$tableName
];
$defaultTbleName
=
$tableName
;
$defaultTbleName
=
$tableName
;
$tableName
=
$tableName
.
'_'
.
self
::
getDbNum
(
$className
);
$tableName
=
$tableName
.
'_'
.
self
::
getDbNum
(
$className
);
//设置分表对应的className
//设置分表对应的className
EntityCollector
::
setCollector
(
$tableName
,
$defaultTbleName
);
EntityCollector
::
setCollector
(
$tableName
,
$defaultTbleName
);
}
}
}
return
$tableName
;
return
$tableName
;
}
}
...
@@ -57,6 +64,17 @@ class Split
...
@@ -57,6 +64,17 @@ class Split
$splitNum
=
$splitCollector
[
$className
][
'num'
];
$splitNum
=
$splitCollector
[
$className
][
'num'
];
$data
=
RequestContext
::
getContextData
();
$data
=
RequestContext
::
getContextData
();
$storeId
=
$data
[
'userInfo'
][
'storeId'
];
$storeId
=
$data
[
'userInfo'
][
'storeId'
];
if
(
empty
(
$storeId
)
)
{
throw
new
CommonException
([
"msg"
=>
"参数异常,获取店铺信息失败。"
]);
}
return
$storeId
%
$splitNum
;
return
$storeId
%
$splitNum
;
}
}
private
function
isTesting
()
{
/**@var User $user**/
$user
=
App
::
getBean
(
User
::
class
);
return
$user
->
getTestFlag
()
===
TestEnum
::
TEST_STORE_ID
;
}
}
}
\ No newline at end of file
src/Common/Entity/User.php
View file @
d14cc342
...
@@ -11,6 +11,7 @@
...
@@ -11,6 +11,7 @@
namespace
Hdll\Services\Common\Entity
;
namespace
Hdll\Services\Common\Entity
;
use
Hdll\Services\Auth\Enum\AuthError
;
use
Hdll\Services\Auth\Enum\AuthError
;
use
Hdll\Services\Common\Enum\TestEnum
;
use
Hdll\Services\Common\Lib\Redis
;
use
Hdll\Services\Common\Lib\Redis
;
use
Swoft\Bean\Annotation\Bean
;
use
Swoft\Bean\Annotation\Bean
;
use
Swoft\Core\RequestContext
;
use
Swoft\Core\RequestContext
;
...
@@ -35,6 +36,16 @@ class User
...
@@ -35,6 +36,16 @@ class User
return
$this
->
getValue
(
'id'
);
return
$this
->
getValue
(
'id'
);
}
}
public
function
setTestFlag
()
{
$this
->
setValue
(
'testFlag'
,
TestEnum
::
TEST_STORE_ID
);
}
public
function
getTestFlag
()
{
return
$this
->
getValue
(
'testFlag'
);
}
public
function
getNickname
()
public
function
getNickname
()
{
{
return
$this
->
getValue
(
'nickname'
);
return
$this
->
getValue
(
'nickname'
);
...
...
src/Common/Enum/TestEnum.php
0 → 100644
View file @
d14cc342
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/9/25
* Time: 13:22
*/
namespace
Hdll\Services\Common\Enum
;
class
TestEnum
{
const
TEST_STORE_ID
=
true
;
}
src/Store/Lib/StoreInterface.php
View file @
d14cc342
...
@@ -18,6 +18,7 @@ use Swoft\Core\ResultInterface;
...
@@ -18,6 +18,7 @@ use Swoft\Core\ResultInterface;
* @method ResultInterface deferIsCertified(int $storeId)
* @method ResultInterface deferIsCertified(int $storeId)
* @method ResultInterface deferGetStoreByStoreId(int $storeId)
* @method ResultInterface deferGetStoreByStoreId(int $storeId)
* @method ResultInterface deferGetStoreBySellerId(int $sellerId)
* @method ResultInterface deferGetStoreBySellerId(int $sellerId)
* @method ResultInterface deferGetStoreByMobile(int $mobile, array $fields = [])
* @method ResultInterface deferUpdateStore(int $storeId, array $data)
* @method ResultInterface deferUpdateStore(int $storeId, array $data)
* @method ResultInterface deferDeleteStore(int $storeId)
* @method ResultInterface deferDeleteStore(int $storeId)
* @method ResultInterface deferGetWxacodeUrl(int $storeId, int $type, string $page, string $scene)
* @method ResultInterface deferGetWxacodeUrl(int $storeId, int $type, string $page, string $scene)
...
@@ -49,6 +50,15 @@ interface StoreInterface
...
@@ -49,6 +50,15 @@ interface StoreInterface
public
function
getStoreBySellerId
(
int
$sellerId
);
public
function
getStoreBySellerId
(
int
$sellerId
);
/**
/**
* 根据注册手机号获取店铺信息
*
* @param integer $mobile
* @param array $fields 要查询的字段列表 :['id','storeName','addTime']
* @return array
*/
public
function
getStoreByMobile
(
int
$mobile
,
array
$fields
=
[]);
/**
* 根据店铺ID修改店铺信息
* 根据店铺ID修改店铺信息
*
*
* @param integer $storeId
* @param integer $storeId
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment